Préface
Alors que le développement de logiciels se développe rapidement et que la demande continue de croître, les développeurs sont confrontés à davantage de pression et de défis. Les méthodes de développement traditionnelles nécessitent beaucoup de temps et d'énergie, et l'émergence de plateformes de développement low-code offre aux développeurs une méthode de développement plus efficace et plus rapide. Aujourd'hui, l'éditeur prendra comme exemple la création d'un plug-in de commande pour montrer comment utiliser le langage Java pour créer efficacement un plug-in personnalisé.
Préparation environnementale
- Outil de création de plug-ins de grille de type mobile - version Java (forguncyJavaPluginGenerator)
- Concepteur de grille de type mobile (version v10.0 et supérieure)
- Compilateur IDE (par exemple IntelliJ IDEA Community Edition)
- Environnement d'exécution Java
- Version JDK8.0 et supérieure
générateur de plugins
Ouvrez le lien outil Forguncy Java Plugin Generator-Java version ( forguncyJavaPluginGenerator ) et téléchargez le [Forguncy Java Plugin Generator]. Il est recommandé d'utiliser la version compressée du package.
Ouvrez [forguncyJavaExtensionGenerateTool.exe] et configurez les informations de base du plug-in dans l'interface suivante :
Cliquez pour créer le plug-in de commande serveur. Une fois la création terminée, le fichier projet sera généré dans l'ensemble de répertoires correspondant :
Ensuite, utilisez le compilateur IDE pour ouvrir le projet MyPlugin. Après ouverture, le répertoire du projet est comme indiqué ci-dessous :
À ce stade, le travail de préparation préliminaire est terminé. Ensuite, nous écrirons la logique du code.
Code
Ajouter des dépendances
Avant d'implémenter le code, nous devons d'abord ajouter quelques dépendances liées à la grille de type mobile. Comme indiqué ci-dessous, nous devons ajouter les dépendances suivantes au fichier pom :
Remplacez simplement Icon.png et PluginLogo.png par l'icône et le logo du plug-in.
Et [PluginConfig.json] est utilisé pour configurer les informations de base du plug-in :
{
"assembly": [], // 如需要加载其他类
"javascript": [], // 如需加载其他JavaScript文件
"css": [], // 如需加载其他css文件
"image": "resources/PluginLogo.png", // 需要加载图片的相对路径
"description": "这是一个活字格插件", // 插件的文本描述信息
"description_cn": "这是一个活字格插件", // 插件的中文文本描述信息
"name": "MyPlugin", // 插件名称
"name_cn": "我的插件", // 插件中午名称
"pluginType": "command", // 插件类型,当前为命令类型插件
"guid": "fefeb164-ab98-48c8-b309-b5410052e504", // 插件唯一标识GUID,建议勿修改
"version": "1.0.0.0", // 插件版本
"dependenceVersion": "10.0.0.0" // 插件支持依赖最低活字格版本
}
Écrire la logique du code de base
Après avoir terminé la configuration ci-dessus, vous pouvez écrire la logique du plug-in. Ce qui suit est un exemple de code du plug-in, qui génère principalement une signature numérique aléatoire via 5 paramètres (AppSecret, ID de demande, horodatage, données et résultat de la signature).
package org.example;
import com.grapecity.forguncy.LoggerContext;
import com.grapecity.forguncy.commands.ICommandExecutableInServerSide;
import com.grapecity.forguncy.commands.IServerCommandExecuteContext;
import com.grapecity.forguncy.commands.annotation.ResultToProperty;
import com.grapecity.forguncy.commands.annotation.common.Category;
import com.grapecity.forguncy.commands.entity.Command;
import com.grapecity.forguncy.commands.entity.ExecuteResult;
import com.grapecity.forguncy.commands.enumeration.CommandScope;
import com.grapecity.forguncy.plugincommon.common.annotation.*;
import lombok.Data;
import org.apache.commons.codec.binary.Base64;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import javax.servlet.http.HttpServletRequest;
@Data
@Icon( uri= "resources/Icon.png")
@Category(category = "程杰合集")
public class MyPlugin extends Command implements ICommandExecutableInServerSide {
private static final char[] DIGITS = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' };
@DisplayName(displayName = "AppSecret")
@FormulaProperty
@Required
private String appSecret;
@DisplayName(displayName = "请求ID")
@FormulaProperty
@Required
private String requestId;
@DisplayName(displayName = "时间戳")
@FormulaProperty
@Required
private String timestamp;
@DisplayName(displayName = "数据")
@FormulaProperty
@Required
private String data;
@ResultToProperty
@FormulaProperty
@DisplayName(displayName = "签名结果")
private String resultTo = "结果";
@Override
public ExecuteResult execute(IServerCommandExecuteContext dataContext) {
Long innerTimestamp = Long.parseLong(timestamp);
String res = null;
try {
res = sign(appSecret, requestId, innerTimestamp, data);
} catch (Exception e) {
throw new RuntimeException(e);
}
try {
dataContext.getParameters().put(resultTo, res);
} catch (Exception e) {
throw new RuntimeException(e);
}
ExecuteResult executeResult = new ExecuteResult();
executeResult.getReturnValues().put("结果", res);
return executeResult;
}
@Override
public boolean getDesignerPropertyVisible(String propertyName, CommandScope commandScope) {
return super.getDesignerPropertyVisible(propertyName, commandScope);
}
@Override
public String toString() {
return "签名程杰";
}
public static String sign(String appSecret, String requestId, Long timestamp, String data) throws Exception{
// 1.签名参数按自然升序排列,拼接上data
StringBuilder sb = new StringBuilder();
sb.append("appSecret=").append(appSecret).append("&")
.append("requestId=").append(requestId).append("&")
.append("timestamp=").append(timestamp)
.append(data);
// 2.对签名字符串base64编码后获取32位md5值
// 2.对签名字符串base64编码后获取32位md5值
String base64Encode = base64Encode(sb.toString().getBytes("UTF-8"));
String md5Value = md5(base64Encode);
// 3.将得到的MD5值进行sha1散列,转换为16进制字符串
String sign = sha1(md5Value);
return sign;
}
/**
* 对字符串进行MD5加密,得到32位MD5值
* @param text 明文
* @return 密文
*/
public static String md5(String text) {
try {
MessageDigest msgDigest = MessageDigest.getInstance("MD5");
msgDigest.update(text.getBytes("UTF-8"));
byte[] bytes = msgDigest.digest();
// 转成16进制
return new String(encodeHex(bytes));
} catch (NoSuchAlgorithmException e) {
throw new IllegalStateException("System doesn't support MD5 algorithm.");
} catch (UnsupportedEncodingException e) {
throw new IllegalStateException("System doesn't support your EncodingException.");
}
}
/***
* SHA加密
* @return
*/
public static String sha1(String content) throws Exception {
MessageDigest sha = MessageDigest.getInstance("SHA1");
byte[] byteArray = content.getBytes("UTF-8");
return new String(encodeHex(sha.digest(byteArray)));
}
/**
* base64编码
*
* @param content
* @return
* @throws Exception
*/
public static String base64Encode(byte[] content) throws Exception {
return Base64.encodeBase64String(content).replaceAll("(\\\r\\\n|\\\r|\\\n|\\\n\\\r)", "");
}
/**
* base64解码
*
* @param content
* @return
* @throws Exception
*/
public static byte[] base64Decode(String content) throws Exception {
return Base64.decodeBase64(content);
}
/**
* 转换成16进制
* @param data
* @return
*/
private static char[] encodeHex(byte[] data) {
int l = data.length;
char[] out = new char[l << 1];
// two characters form the hex value.
for (int i = 0, j = 0; i < l; i++) {
out[j++] = DIGITS[(0xF0 & data[i]) >>> 4];
out[j++] = DIGITS[0x0F & data[i]];
}
return out;
}
public static String getPostData(HttpServletRequest request) {
StringBuilder data = new StringBuilder();
String line;
BufferedReader reader;
try {
reader = request.getReader();
while (null != (line = reader.readLine())) {
data.append(line);
}
} catch (IOException e) {
return null;
}
return data.toString();
}
}
Utiliser Maven pour empaqueter des plug-ins
Une fois le code écrit, emballez l'intégralité du projet : cliquez sur [nettoyer] ici, puis cliquez sur [installer] :
Ensuite, le produit packagé apparaîtra dans le répertoire [target] :
Installez ensuite le plug-in zip fourni dans le concepteur de grille de type mobile et utilisez-le.
Créez une nouvelle commande et vous pourrez trouver le plug-in que vous venez de conditionner dans la sélection de commandes.
Remplissez les paramètres :
Cela peut être testé dans la commande côté serveur :
Comme vous pouvez le voir, une signature numérique aléatoire est renvoyée dans les résultats du test ci-dessus. Ainsi, un plug-in construit en langage Java a été développé.
Résumer
Ce qui précède décrit l'ensemble du processus d'utilisation de Java pour développer un plug-in de commande dans une plate-forme low-code. Si vous souhaitez en savoir plus, veuillez cliquer ici pour le voir.
Lien d'extension :
Qu’est-ce qu’une plateforme de développement low-code ?
Un camarade de poulet "open source" deepin-IDE et a finalement réalisé l'amorçage ! Bon gars, Tencent a vraiment transformé Switch en une « machine d'apprentissage pensante » Examen des échecs de Tencent Cloud le 8 avril et explication de la situation Reconstruction du démarrage du bureau à distance RustDesk Client Web La base de données de terminal open source de WeChat basée sur SQLite WCDB a inauguré une mise à niveau majeure Liste d'avril TIOBE : PHP est tombé à un plus bas historique, Fabrice Bellard, le père de FFmpeg, a sorti l'outil de compression audio TSAC , Google a sorti un gros modèle de code, CodeGemma , est-ce que ça va vous tuer ? C'est tellement bon qu'il est open source - outil d'édition d'images et d'affiches open source