Нет описания

DelNoRealnameSMD.java 4.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. package com.shuhaiwifi.task;
  2. import cn.hutool.core.codec.Base64;
  3. import cn.hutool.crypto.Mode;
  4. import cn.hutool.crypto.Padding;
  5. import cn.hutool.crypto.symmetric.AES;
  6. import com.alibaba.fastjson.JSONObject;
  7. import com.shuhaiwifi.task.util.Utils;
  8. import org.apache.commons.logging.Log;
  9. import org.apache.commons.logging.LogFactory;
  10. import javax.crypto.spec.IvParameterSpec;
  11. import javax.crypto.spec.SecretKeySpec;
  12. import java.io.IOException;
  13. import java.nio.charset.StandardCharsets;
  14. import java.text.SimpleDateFormat;
  15. import java.util.List;
  16. import java.util.Map;
  17. public class DelNoRealnameSMD
  18. {
  19. private final static Log logger = LogFactory.getLog(DelNoRealnameSMD.class);
  20. static String appId="6vGGHwa43CHshDBfDZcuG3vX43weRCwj";
  21. static String appSecret="9XPzT9OUvmu2iSCq5gURllS5TEjt2WbP";
  22. static String tenantId="1452902210060161024";
  23. static String encodeKey="uBdUx82vPHkDKb284d7NkjFoNcKWBuka";
  24. static String ivKey="oCRU0D1wKfBlNeTz";
  25. static String password="Zeng@2024";
  26. static String token="";
  27. public static void main(String[] args) throws IOException {
  28. String appurl="https://sop.mingy-iot.com";
  29. String url=appurl+"/auc/oauth/token";
  30. String para="username=zeng&password="+getEncodePassWord()+"&grant_type=password&scope=server";
  31. String c=Utils.getContentByPost(url,para, tenantId, getLoginAuthorization(),1,"POST");
  32. JSONObject resJson = JSONObject.parseObject(c);
  33. token = resJson.getString("access_token");
  34. SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  35. List<Map<String,Object>> simlist=RCPService.getSimpService().getMapList("select iccid from sim where scgrpid=14 ");
  36. StringBuilder iccidbuilder = new StringBuilder();
  37. int norealnamesimsize=0;
  38. int delsmdsize=0;
  39. for (Map<String, Object> item : simlist) {
  40. String iccid=String.valueOf(item.get("iccid"));
  41. String url2=appurl+"/platform/api/device/device-realname-status?iccid="+iccid;
  42. String c2= null;
  43. try {
  44. c2 = Utils.getContentByPost(url2,"", tenantId, getAuthorization(),0,"GET");
  45. } catch (IOException e) {
  46. throw new RuntimeException(e);
  47. }
  48. JSONObject resJson2 = JSONObject.parseObject(c2);
  49. JSONObject data = resJson2.getJSONObject("data");
  50. String realNameStatus=data.getString("realNameStatus");
  51. if ("0".equals(realNameStatus)) {
  52. // System.out.println(iccid+"==========>"+c2);
  53. norealnamesimsize++;
  54. String sql="select sn from smd where iccid='"+iccid+"'";
  55. List<Map<String,Object>> smdlist=RCPService.getBaseService().getMapList(sql);
  56. if (smdlist != null && !smdlist.isEmpty()) {
  57. String sn = String.valueOf(smdlist.get(0).get("sn"));
  58. long between = 12 * 60 * 60 * 1000;
  59. sql = "select devid,lastcntm from device" + Long.parseLong(sn) % 32 + " where devid='" + sn + "' ";
  60. List<Map<String, Object>> devlist = RCPService.getMifiService().getMapList(sql);
  61. long lastcntm = Long.parseLong(devlist.get(0).get("lastcntm").toString());
  62. if (devlist != null && !devlist.isEmpty() && System.currentTimeMillis() - lastcntm < between) {
  63. } else {
  64. if (devlist != null && !devlist.isEmpty()) {
  65. logger.info(sn + "==========>" + sdf.format(lastcntm) + "===>" + iccid);
  66. }
  67. iccidbuilder.append("'").append(iccid).append("'").append(",");
  68. delsmdsize++;
  69. }
  70. }
  71. }
  72. }
  73. logger.info("未实名的卡数:"+norealnamesimsize+"==>需要删除12小时没有上线的设备卡数量:"+delsmdsize);
  74. if (iccidbuilder.length()>0){
  75. String delsql = "delete from smd where iccid in ("+iccidbuilder.substring(0,iccidbuilder.length()-1)+")";
  76. logger.info(delsmdsize+"==>"+delsql);
  77. RCPService.getBaseService().execSql(delsql);
  78. }
  79. }
  80. public static String getAuthorization(){
  81. return "Bearer " + token;
  82. }
  83. public static String getLoginAuthorization(){
  84. return "Basic " + Base64.encode(appId + ":" + appSecret);
  85. }
  86. public static String getEncodePassWord(){
  87. AES aes = new AES(Mode.CBC, Padding.ZeroPadding,
  88. new SecretKeySpec(encodeKey.getBytes(),"AES"),
  89. new IvParameterSpec(ivKey.getBytes()));
  90. return aes.encryptBase64(password, StandardCharsets.UTF_8);
  91. }
  92. }