欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java實現(xiàn)企業(yè)微信消息推送功能的詳細步驟

 更新時間:2022年04月13日 14:49:36   作者:淺夏yhy  
這篇文章主要介紹了Java實現(xiàn)企業(yè)微信消息推送功能,本文圖文實例代碼相結合給大家介紹的非常詳細,需要的朋友可以參考下

第一步:申請企業(yè)微信注冊企業(yè)(鏈接:https://work.weixin.qq.com/nl/sem/registe?s=c&from=1011017189&bd_vid=11628667012427618020)

第二步:登錄自己的企業(yè)微信找到應用管理———>添加應用

第三步:獲取到應用的AgentId、Secret、企業(yè)id

第四步,準備代碼編寫:

model層代碼:

package com.toone.itop.formula.function.inte.model;  
  
/**
 * @desc  : 微信通用接口憑證 
 * 
 */
public class AccessToken {  
    // 獲取到的憑證  
    private String token;  
    // 憑證有效時間,單位:秒  
    private int expiresIn;  
    public String getToken() {  
        return token;  
    }  
    public void setToken(String token) {  
        this.token = token;  
    public int getExpiresIn() {  
        return expiresIn;  
    public void setExpiresIn(int expiresIn) {  
        this.expiresIn = expiresIn;  
}  
package com.toone.itop.formula.function.inte.model;  
  
/**
 * 消息基類(企業(yè)號 -> 普通用戶) 
 *
 */
public class BaseMessage {  
    // 否 成員ID列表(消息接收者,多個接收者用‘|'分隔,最多支持1000個)。特殊情況:指定為@all,則向該企業(yè)應用的全部成員發(fā)送
    private String touser;  
    // 否 部門ID列表,多個接收者用‘|'分隔,最多支持100個。當touser為@all時忽略本參數(shù)
    private String toparty;  
    // 否 標簽ID列表,多個接收者用‘|'分隔,最多支持100個。當touser為@all時忽略本參數(shù)
    private String totag;  
    // 是 消息類型 
    private String msgtype; 
    // 是 企業(yè)應用的id,整型??稍趹玫脑O置頁面查看
    private int agentid;
    
    public String getTouser() {
        return touser;
    }
    public void setTouser(String touser) {
        this.touser = touser;
    public String getToparty() {
        return toparty;
    public void setToparty(String toparty) {
        this.toparty = toparty;
    public String getTotag() {
        return totag;
    public void setTotag(String totag) {
        this.totag = totag;
    public String getMsgtype() {
        return msgtype;
    public void setMsgtype(String msgtype) {
        this.msgtype = msgtype;
    public int getAgentid() {
        return agentid;
    public void setAgentid(int agentid) {
        this.agentid = agentid;
}
package com.toone.itop.formula.function.inte.model;
/**
 * 文本
 *
 */
public class Text {
    //是    消息內容,最長不超過2048個字節(jié)
    private String content;
    public String getContent() {
        return content;
    }
    public void setContent(String content) {
        this.content = content;
}
package com.toone.itop.formula.function.inte.model;
/**
 * 文本消息
 *
 */
public class TextMessage extends BaseMessage {
    // 文本
    private Text text;
    // 否 表示是否是保密消息,0表示否,1表示是,默認0
    private int safe;
    public Text getText() {
        return text;
    }
    public void setText(Text text2) {
        this.text = text2;
    }
    public int getSafe() {
        return safe;
    }
    public void setSafe(int safe) {
        this.safe = safe;
    }
}

通用工具類:

package com.toone.itop.formula.function.inte.util;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
import javax.net.ssl.X509TrustManager;
/**
 * 證書信任管理器(用于https請求
 * 
 */
public class MyX509TrustManager implements X509TrustManager {
    public void checkClientTrusted(X509Certificate[] chain, String authType) throws CertificateException {
    }
    public void checkServerTrusted(X509Certificate[] chain, String authType) throws CertificateException {
    public X509Certificate[] getAcceptedIssuers() {
        return null;
}
package com.toone.itop.formula.function.inte.util;
/**
 * 企業(yè)微信參數(shù)
 *
 */
public class WeChatParamesUtil {
    // 1.微信參數(shù)
    // 企業(yè)ID
    public final static String corpId = "ww0b7de3b4c25ba7881";
    // 企業(yè)應用私鑰OA  
    public final static String corpsecret = "xbV7an7Mev8yqsnSzzzSn0L_cCnOTJxbo9gVZR7ObpY1";
    // 企業(yè)應用的id  
    public final static int agentId = 1000008;
    
    public final static String aws6url = "http://localhost:8088";
}
package com.toone.itop.formula.function.inte.util;
import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.net.ConnectException;
import java.net.URL;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSocketFactory;
import javax.net.ssl.TrustManager;
import net.sf.json.JSONException;
import net.sf.json.JSONObject;
import com.toone.itop.formula.function.inte.model.AccessToken;
public class WeChatUtil {
    // 微信的請求url
    // 獲取access_token的接口地址(GET) 限200(次/天)
    public final static String access_token_url = "https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={corpId}&corpsecret={corpsecret}";
    /**
     * 1.發(fā)起https請求并獲取結果
     * 
     * @param requestUrl
     *            請求地址
     * @param requestMethod
     *            請求方式(GET、POST)
     * @param outputStr
     *            提交的數(shù)據(jù)
     * @return JSONObject(通過JSONObject.get(key)的方式獲取json對象的屬性值)
     */
    public static JSONObject httpRequest(String requestUrl, String requestMethod, String outputStr) {
        JSONObject jsonObject = null;
        StringBuffer buffer = new StringBuffer();
        try {
            // 創(chuàng)建SSLContext對象,并使用我們指定的信任管理器初始化
            TrustManager[] tm = { new MyX509TrustManager() };
            SSLContext sslContext = SSLContext.getInstance("SSL", "SunJSSE");
            sslContext.init(null, tm, new java.security.SecureRandom());
            // 從上述SSLContext對象中得到SSLSocketFactory對象
            SSLSocketFactory ssf = sslContext.getSocketFactory();
            URL url = new URL(requestUrl);
            HttpsURLConnection httpUrlConn = (HttpsURLConnection) url.openConnection();
            httpUrlConn.setSSLSocketFactory(ssf);
            httpUrlConn.setDoOutput(true);
            httpUrlConn.setDoInput(true);
            httpUrlConn.setUseCaches(false);
            // 設置請求方式(GET/POST)
            httpUrlConn.setRequestMethod(requestMethod);
            if ("GET".equalsIgnoreCase(requestMethod))
                httpUrlConn.connect();
            // 當有數(shù)據(jù)需要提交時
            if (null != outputStr) {
                OutputStream outputStream = httpUrlConn.getOutputStream();
                // 注意編碼格式,防止中文亂碼
                outputStream.write(outputStr.getBytes("UTF-8"));
                outputStream.close();
            }
            // 將返回的輸入流轉換成字符串
            InputStream inputStream = httpUrlConn.getInputStream();
            InputStreamReader inputStreamReader = new InputStreamReader(inputStream, "UTF-8");
            BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
            String str = null;
            while ((str = bufferedReader.readLine()) != null) {
                buffer.append(str);
            bufferedReader.close();
            inputStreamReader.close();
            // 釋放資源
            inputStream.close();
            inputStream = null;
            httpUrlConn.disconnect();
            jsonObject = JSONObject.fromObject(buffer.toString());
        } catch (ConnectException ce) {
            // Weixin server connection timed out
        } catch (Exception e) {
            // https request error:{}
            // e.printStackTrace();
        }
        return jsonObject;
    }
     * 2.獲取access_token
     * @param appid
     *            憑證
     * @param appsecret
     *            密鑰
     * @return
    public static AccessToken getAccessToken(String appid, String appsecret) {
        AccessToken accessToken = null;
        String requestUrl = access_token_url.replace("{corpId}", appid).replace("{corpsecret}", appsecret);
        JSONObject jsonObject = httpRequest(requestUrl, "GET", null);
        // 如果請求成功
        if (null != jsonObject) {
            try {
                accessToken = new AccessToken();
                accessToken.setToken(jsonObject.getString("access_token"));
                accessToken.setExpiresIn(jsonObject.getInt("expires_in"));
            } catch (JSONException e) {
                accessToken = null;
                // 獲取token失敗
                // log.error("獲取token失敗 errcode:{} errmsg:{}"+
                // jsonObject.getInt("errcode")+jsonObject.getString("errmsg"));
        return accessToken;
}

service層:

package com.toone.itop.formula.function.inte.service;
import net.sf.json.JSONObject;
import com.google.gson.Gson;
import com.toone.itop.formula.function.inte.model.Text;
import com.toone.itop.formula.function.inte.model.TextMessage;
import com.toone.itop.formula.function.inte.util.WeChatParamesUtil;
import com.toone.itop.formula.function.inte.util.WeChatUtil;
/**
 * @desc : 發(fā)送消息
 * 
 */
public class WeChatService {
    private static String sendMessage_url = "https://qyapi.weixin.qq.com/cgi-bin/message/send?access_token=ACCESS_TOKEN";
    /**
     * @desc :0.公共方法:發(fā)送消息
     * @param accessToken
     * @param message
     *            void
     */
    public static String sendMessage(String uid, String content) {
        // 1.獲取access_token:根據(jù)企業(yè)id和應用密鑰獲取access_token,并拼接請求url
        String accessToken = WeChatUtil.getAccessToken(WeChatParamesUtil.corpId, WeChatParamesUtil.corpsecret).getToken();
        // 2.獲取發(fā)送對象,并轉成json
        Gson gson = new Gson();
        TextMessage message = new TextMessage();
        // 1.1非必需
        message.setTouser(uid); // 不區(qū)分大小寫
        //message.setToparty("1");
        //message.getTouser(totag);
        // txtMsg.setSafe(0);
        // 1.2必需
        message.setMsgtype("text");
        message.setAgentid(WeChatParamesUtil.agentId);
        Text text = new Text();
        text.setContent(content);
        message.setText(text);
        String jsonMessage = gson.toJson(message);
        // 3.獲取請求的url
        String url = sendMessage_url.replace("ACCESS_TOKEN", accessToken);
        // 4.調用接口,發(fā)送消息
        JSONObject jsonObject = WeChatUtil.httpRequest(url, "POST", jsonMessage);
        // 4.錯誤消息處理
        if (null != jsonObject) {
            if (0 != jsonObject.getInt("errcode")) {
                System.out.println("消息發(fā)送失敗 errcode:{} errmsg:{}" + jsonObject.getInt("errcode") + jsonObject.getString("errmsg"));
            }
        }
        return jsonObject.toString();
    }
    public static void main(String[] args) {
        // 0.設置消息內容
        String content = "這是一條測試消息";
        //userId為企業(yè)用戶的id
        String userId = "qianxia";
        // 3.發(fā)送消息:調用業(yè)務類,發(fā)送消息
        WeChatService.sendMessage(userId, content);
    }
}

所需引入的依賴

測試效果圖:

到此這篇關于Java實現(xiàn)企業(yè)微信消息推送功能的文章就介紹到這了,更多相關java企業(yè)微信消息推送內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Springboot如何去掉URL后面的jsessionid

    Springboot如何去掉URL后面的jsessionid

    這篇文章主要介紹了Springboot如何去掉URL后面的jsessionid,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-11-11
  • Java?super關鍵字的使用詳解

    Java?super關鍵字的使用詳解

    java中的super關鍵字是一個引用變量,用于引用直接父類對象,下面這篇文章主要給大家介紹一下super關鍵字的使用,需要的朋友可以參考下
    2022-07-07
  • Spring和SpringBoot比較及區(qū)別解惑

    Spring和SpringBoot比較及區(qū)別解惑

    這篇文章主要介紹了Spring和SpringBoot比較解惑區(qū)別,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-06
  • 使用Springboot整合Apollo配置中心

    使用Springboot整合Apollo配置中心

    這篇文章主要介紹了使用Springboot整合Apollo配置中心的操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java集合WeakHashMap源碼分析

    Java集合WeakHashMap源碼分析

    這篇文章主要介紹了Java集合WeakHashMap源碼分析,和HashMap一樣,WeakHashMap 也是一個散列表,它存儲的內容也是鍵值對(key-value)映射,而且鍵和值都可以是null,需要的朋友可以參考下
    2023-09-09
  • Java新手教程之ArrayList的基本使用

    Java新手教程之ArrayList的基本使用

    ArrayList就是傳說中的動態(tài)數(shù)組,用MSDN中的說法,就是Array的復雜版本,這篇文章主要給大家介紹了關于Java新手教程之ArrayList基本使用的相關資料
    2021-06-06
  • Java超詳細介紹封裝與訪問控制修符

    Java超詳細介紹封裝與訪問控制修符

    封裝是一個非常廣泛的概念,小到一個屬性的封裝,大到一個框架或者一個項目的封裝,文中通過實例代碼將詳細介紹封裝與訪問控制修飾符
    2022-05-05
  • java實現(xiàn)視頻轉碼工具類

    java實現(xiàn)視頻轉碼工具類

    這篇文章主要介紹了java實現(xiàn)視頻轉碼,涉及到工具類用到的參數(shù),本文通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • java布局管理之CardLayout簡單實例

    java布局管理之CardLayout簡單實例

    這篇文章主要為大家詳細介紹了java布局管理之CardLayout的簡單實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03
  • 談談對Java多態(tài)性的一點理解

    談談對Java多態(tài)性的一點理解

    多態(tài)就是指程序中定義的引用變量所指向的具體類型和通過該引用變量發(fā)出的方法調用在編程時并不確定,而是在程序運行期間才確定,即一個引用變量倒底會指向哪個類的實例對象,該引用變量發(fā)出的方法調用到底是哪個類中實現(xiàn)的方法,必須在由程序運行期間才能決定
    2017-08-08

最新評論