「java微信接口开发」java调用微信接口

博主:adminadmin 2022-11-28 14:48:12 71

今天给各位分享java微信接口开发的知识,其中也会对java调用微信接口进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

怎么用java调用微信支付接口

1.调用微信接口授权

授权这里有两种方式,一种是snsapi_bases,另一种是snsapi_userinfo,这里官方文档介绍的比较清楚,可以参考官网

;t=resource/res_listverify=1id=open1419316505token=lang=zh_CN

appid 登录微信公众号-基本配置-开发者ID-APPID

redirect_uri 就是一个回调地址,当你调用完微信的这个链接后,他会自动调用你定义的这个地址,返回code参数

注意,redirect_uri 也需要在公众号里面配置,在接口权限-网页帐号里修改。

2.可以在页面中写一个调用授权的页面

%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%  

!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "

%  

String path = request.getContextPath();  

String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";  

%  

html  

head  

title用户管理/title  

script type="text/javascript" src="js/jquery/jquery-1.11.1.min.js"/script  

script type="text/javascript"  

    function oauth() {  

        var url =  "%=basePath%getOauth2Url";  

        $.ajax({  

            url: url,  

            success : function(result){  

                //var result = eval('('+result+')');  

                if (result.success){  

                    location.href = result.obj; //

                } else {  

                }  

            }  

        });  

    }  

/script  

/head  

  

body  

    p onclick="oauth()"非用户认证鉴权/p  

/body  

/html

/prepre class="html" name="code" snippet_file_name="blog_20160608_3_8825275" code_snippet_id="1711669"java中的方法  

pre class="html" name="code"    /**  

     * 获取授权地址  

     * @return  

     */  

    @RequestMapping(value = "/getOauth2Url",method = RequestMethod.GET)  

    public void getOauth2Url(Model model, HttpServletResponse response) {  

          Json j = new Json();  

            try {  

                String authorize_url = PayConfig.AUTHORIZE_URL;  

                String appId = PayConfig.APPID;  

                String redirect_uri = PayConfig.REDIRECT_URI;  

                String url = authorize_url + "?appid=" + appId + "redirect_uri=" + urlEncodeUTF8(redirect_uri) + "response_type=codescope=snsapi_basestate=STATE#wechat_redirect";  

                System.out.println(url);  

                j.setSuccess(true);  

                j.setMsg("保存成功!");  

                j.setObj(url);  

                write(response, JSON.toJSONString(j));  

            } catch (Exception e) {  

                j.setMsg(e.getMessage());  

            }  

    }  

      

    /**  

     * 对回调地址进行encode  

     * @param source  

     * @return  

     */  

    public static String urlEncodeUTF8(String source){  

        String result = source;  

        try {  

                result = java.net.URLEncoder.encode(source,"utf-8");  

        } catch (UnsupportedEncodingException e) {  

                e.printStackTrace();  

        }  

        return result;  

    }  

pre class="html" name="code" /**

 * 获取授权地址

 * @return

 */

@RequestMapping(value = "/getOauth2Url",method = RequestMethod.GET)

    public void getOauth2Url(Model model, HttpServletResponse response) {

  Json j = new Json();

        try {

         String authorize_url = PayConfig.AUTHORIZE_URL;

     String appId = PayConfig.APPID;

     String redirect_uri = PayConfig.REDIRECT_URI;

     String url = authorize_url + "?appid=" + appId + "redirect_uri=" + urlEncodeUTF8(redirect_uri) + "response_type=codescope=snsapi_basestate=STATE#wechat_redirect";

     System.out.println(url);

            j.setSuccess(true);

            j.setMsg("保存成功!");

            j.setObj(url);

            write(response, JSON.toJSONString(j));

        } catch (Exception e) {

            j.setMsg(e.getMessage());

        }

    }

/**

 * 对回调地址进行encode

 * @param source

 * @return

 */

public static String urlEncodeUTF8(String source){

        String result = source;

        try {

                result = java.net.URLEncoder.encode(source,"utf-8");

        } catch (UnsupportedEncodingException e) {

                e.printStackTrace();

        }

        return result;

}

package com.crm.common;  

  

public class PayConfig {  

    public static String APPID = "wx91af774aae000dcb"; //APPID  

    public static String MCHID = "1347742701";         //商户编号  

    public static String PAYKEY = "kong6a9829e4b49a0d2347b4162da6b7";          //支付密钥  

    public static String  APPSECRET  = "f8e1ff34070a94332b3b128232acb5abf "; //公众号-基本配置-APPSECRET密钥  

    public static String REDIRECT_URI = "

回调地址  

    public static String AUTHORIZE_URL = "

微信授权地址  

    public static String ACCESS_TOKEN_URI = "

    public static String SCOPE = "snsapi_base";        //snsapi_base和snsapi_userinfo  

    public static String GRANT_TYPE = "grant_type"; //获取openid时用,不用改  

}  

3.成功后,回到你当时写的回调地址  

pre class="html" name="code"/**  

     * 微信授权后的回调地址的方法  

     * @param code  

     * @param response  

     */  

    @RequestMapping(value = "/authorize",method = RequestMethod.GET)  

    public void authorize(String code, HttpServletResponse response, String openid) {  

        code = "test";  

        String access_token_uri = PayConfig.ACCESS_TOKEN_URI;  

        String appid = PayConfig.APPID;  

        String secret = PayConfig.APPSECRET;  

        access_token_uri = access_token_uri.replace("APPID", appid).replace("SECRET", secret).replace("CODE", code);  

        System.out.println(access_token_uri);  

        if(openid != null){  

            UniteOrder order = getUniteOrder(openid);  

            String reqXML = PayImpl.generateXML(order, PayConfig.PAYKEY);  

            String respXML = PayImpl.requestWechat(ORDER_URL, reqXML);  

            System.out.println("respXML=" + respXML);  

            UniteOrderResult result = (UniteOrderResult) PayImpl.turnObject(UniteOrderResult.class, respXML);  

            getWechatPay(result);  

        }  

    }

如何实现java程序与微信公众平台之间实现消息推送

java程序与微信公众平台之间实现消息推送方法:

1、本地数据库中存放着小程序用户表和微信公众号的表,下面就是向某一个小程序用户推送微信公众号信息

2、在小程序用户表中任意取一个用户A信息,用户A的openId和unionId,通过unionId到公众号表里去检索对应的A用户微信公众号的openId

3、在微信公众号上选择一个模板消息,编辑完要发送的的内容后,再请求发送模板消息的接口

关于微信公众号不能推送的,或者推送报错的,推送的miniprogram下的appid对应的小程序必须是已审核并发布的才可以推送。

推送软件用极光推送,实现多种消息类型,开发者可以轻松地通过极光发送各个移动平台的系统通知,还可以在控制台编辑多种富文本展示模板; 极光还提供自定义消息的透传,客户端接到消息内容后根据自己的逻辑自由处理。

怎么搭建微信公众平台java开发环境??

这个比较复杂,首先需要申请一个微信公众的订阅好或服务号,还要开通各种接口,然后在本地安装java开发环境,包括开发工具如eclipse,myeclipse。最重要的是能在公网有一个地址映射到本地,如果是在局域网,则需要借助第三方工具,推荐使用花生壳、nat123,其中nat123是个比较好的工具,很好的解决了运营商80端口封锁的问题,因为微信公众平台配置服务器的URL只能是80端口。有什么不清楚的可以私信我。

求助贴,微信公众号开发java版的,怎么获取用

微信提供了接口可以获取内容:在关注者与公众号产生消息交互后,公众号可获得关注者的OpenID(加密后的微信号,每个用户对每个公众号的OpenID是唯一的。对于不同公众号,同一用户的openid不同)。公众号可通过本接口来根据OpenID获取用户基本信息,包括昵称、头像、性别、所在城市、语言和关注时间。开发者可通过OpenID来获取用户基本信息。请使用https协议。我们可以看看官方的文档:获取用户的基本信息。接口调用请求说明http请求方式:GET/cgi-bin/user/info?access_token=ACCESS_TOKENopenid=OPENIDlang=zh_CN参数说明参数是否必须说明access_token是调用接口凭证openid是普通用户的标识,对当前公众号唯一lang否返回国家地区语言版本,zh_CN简体,zh_TW繁体,en英语返回说明正常情况下,微信会返回下述JSON数据包给公众号:{"subscribe":1,"openid":"o6_bmjrPTlm6_2sgVt7hMZOPfL2M","nickname":"Band","sex":1,"language":"zh_CN","city":"广州","province":"广东","country":"中国","headimgurl":"/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/0","subscribe_time":1382694957,"unionid":"o6_bmasdasdsad6_2sgVt7hMZOPfL""remark":"","groupid":0}参数说明参数说明subscribe用户是否订阅该公众号标识,值为0时,代表此用户没有关注该公众号,拉取不到其余信息。openid用户的标识,对当前公众号唯一nickname用户的昵称sex用户的性别,值为1时是男性,值为2时是女性,值为0时是未知city用户所在城市country用户所在国家province用户所在省份language用户的语言,简体中文为zh_CNheadimgurl用户头像,最后一个数值代表正方形头像大小(有0、46、64、96、132数值可选,0代表640*640正方形头像),用户没有头像时该项为空。若用户更换头像,原有头像URL将失效。subscribe_time用户关注时间,为时间戳。如果用户曾多次关注,则取最后关注时间unionid只有在用户将公众号绑定到微信开放平台帐号后,才会出现该字段。详见:获取用户个人信息(UnionID机制)remark公众号运营者对粉丝的备注,公众号运营者可在微信公众平台用户管理界面对粉丝添加备注groupid用户所在的分组ID错误时微信会返回错误码等信息,JSON数据包示例如下(该示例为AppID无效错误):{"errcode":40013,"errmsg":"invalidappid"}

如何使用java开发微信公众平台接口

1、首先,要在微信公众平台给你的账号申请到“高级功能” ;前台也就是菜单要想个性化设置必须要有这个功能,不然你只能添加菜单和关闭,但不能删除,还有自动回复也是。

2、后台要看你自己了。

如何用java开发微信

说明:

本次的教程主要是对微信公众平台开发者模式的讲解,网络上很多类似文章,但很多都让初学微信开发的人一头雾水,所以总结自己的微信开发经验,将微信开发的整个过程系统的列出,并对主要代码进行讲解分析,让初学者尽快上手。

在阅读本文之前,应对微信公众平台的官方开发文档有所了解,知道接收和发送的都是xml格式的数据。另外,在做内容回复时用到了图灵机器人的api接口,这是一个自然语言解析的开放平台,可以帮我们解决整个微信开发过程中最困难的问题,此处不多讲,下面会有其详细的调用方式。

1.1 在登录微信官方平台之后,开启开发者模式,此时需要我们填写url和token,所谓url就是我们自己服务器的接口,用WechatServlet.java来实现,相关解释已经在注释中说明,代码如下:

[java] view plain copy

package demo.servlet;

import java.io.BufferedReader;

import java.io.IOException;

import java.io.InputStream;

import java.io.InputStreamReader;

import java.io.OutputStream;

import javax.servlet.ServletException;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import demo.process.WechatProcess;

/**

* 微信服务端收发消息接口

*

* @author pamchen-1

*

*/

public class WechatServlet extends HttpServlet {

/**

* The doGet method of the servlet. br

*

* This method is called when a form has its tag value method equals to get.

*

* @param request

*            the request send by the client to the server

* @param response

*            the response send by the server to the client

* @throws ServletException

*             if an error occurred

* @throws IOException

*             if an error occurred

*/

public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

request.setCharacterEncoding("UTF-8");

response.setCharacterEncoding("UTF-8");

/** 读取接收到的xml消息 */

StringBuffer sb = new StringBuffer();

InputStream is = request.getInputStream();

InputStreamReader isr = new InputStreamReader(is, "UTF-8");

BufferedReader br = new BufferedReader(isr);

String s = "";

while ((s = br.readLine()) != null) {

sb.append(s);

}

String xml = sb.toString(); //次即为接收到微信端发送过来的xml数据

String result = "";

/** 判断是否是微信接入激活验证,只有首次接入验证时才会收到echostr参数,此时需要把它直接返回 */

String echostr = request.getParameter("echostr");

if (echostr != null  echostr.length()  1) {

result = echostr;

} else {

//正常的微信处理流程

result = new WechatProcess().processWechatMag(xml);

}

try {

OutputStream os = response.getOutputStream();

os.write(result.getBytes("UTF-8"));

os.flush();

os.close();

} catch (Exception e) {

e.printStackTrace();

}

}

/**

* The doPost method of the servlet. br

*

* This method is called when a form has its tag value method equals to

* post.

*

* @param request

*            the request send by the client to the server

* @param response

*            the response send by the server to the client

* @throws ServletException

*             if an error occurred

* @throws IOException

*             if an error occurred

*/

public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException, IOException {

doGet(request, response);

}

}

1.2 相应的web.xml配置信息如下,在生成WechatServlet.java的同时,可自动生成web.xml中的配置。前面所提到的url处可以填写例如:http;//服务器地址/项目名/wechat.do

[html] view plain copy

?xml version="1.0" encoding="UTF-8"?

web-app version="2.5"

xmlns=""

xmlns:xsi=""

xsi:schemaLocation="

"

servlet

descriptionThis is the description of my J2EE component/description

display-nameThis is the display name of my J2EE component/display-name

servlet-nameWechatServlet/servlet-name

servlet-classdemo.servlet.WechatServlet/servlet-class

/servlet

servlet-mapping

servlet-nameWechatServlet/servlet-name

url-pattern/wechat.do/url-pattern

/servlet-mapping

welcome-file-list

welcome-fileindex.jsp/welcome-file

/welcome-file-list

/web-app

1.3 通过以上代码,我们已经实现了微信公众平台开发的框架,即开通开发者模式并成功接入、接收消息和发送消息这三个步骤。

下面就讲解其核心部分——解析接收到的xml数据,并以文本类消息为例,通过图灵机器人api接口实现智能回复。

2.1 首先看一下整体流程处理代码,包括:xml数据处理、调用图灵api、封装返回的xml数据。

[java] view plain copy

package demo.process;

import java.util.Date;

import demo.entity.ReceiveXmlEntity;

/**

* 微信xml消息处理流程逻辑类

* @author pamchen-1

*

*/

public class WechatProcess {

/**

* 解析处理xml、获取智能回复结果(通过图灵机器人api接口)

* @param xml 接收到的微信数据

* @return  最终的解析结果(xml格式数据)

*/

public String processWechatMag(String xml){

/** 解析xml数据 */

ReceiveXmlEntity xmlEntity = new ReceiveXmlProcess().getMsgEntity(xml);

/** 以文本消息为例,调用图灵机器人api接口,获取回复内容 */

String result = "";

if("text".endsWith(xmlEntity.getMsgType())){

result = new TulingApiProcess().getTulingResult(xmlEntity.getContent());

}

/** 此时,如果用户输入的是“你好”,在经过上面的过程之后,result为“你也好”类似的内容

*  因为最终回复给微信的也是xml格式的数据,所有需要将其封装为文本类型返回消息

* */

result = new FormatXmlProcess().formatXmlAnswer(xmlEntity.getFromUserName(), xmlEntity.getToUserName(), result);

return result;

}

}

2.2 解析接收到的xml数据,此处有两个类,ReceiveXmlEntity.java和ReceiveXmlProcess.java,通过反射的机制动态调用实体类中的set方法,可以避免很多重复的判断,提高代码效率,代码如下:

[java] view plain copy

package demo.entity;

/**

* 接收到的微信xml实体类

* @author pamchen-1

*

*/

public class ReceiveXmlEntity {

private String ToUserName="";

private String FromUserName="";

private String CreateTime="";

private String MsgType="";

private String MsgId="";

private String Event="";

private String EventKey="";

private String Ticket="";

private String Latitude="";

private String Longitude="";

private String Precision="";

private String PicUrl="";

private String MediaId="";

private String Title="";

private String Description="";

private String Url="";

private String Location_X="";

private String Location_Y="";

private String Scale="";

private String Label="";

private String Content="";

private String Format="";

private String Recognition="";

public String getRecognition() {

return Recognition;

}

public void setRecognition(String recognition) {

Recognition = recognition;

}

public String getFormat() {

return Format;

}

public void setFormat(String format) {

Format = format;

}

public String getContent() {

return Content;

}

public void setContent(String content) {

Content = content;

}

public String getLocation_X() {

return Location_X;

}

public void setLocation_X(String locationX) {

Location_X = locationX;

}

public String getLocation_Y() {

return Location_Y;

}

public void setLocation_Y(String locationY) {

Location_Y = locationY;

}

public String getScale() {

return Scale;

}

public void setScale(String scale) {

Scale = scale;

}

public String getLabel() {

return Label;

}

public void setLabel(String label) {

Label = label;

}

public String getTitle() {

return Title;

}

public void setTitle(String title) {

Title = title;

}

public String getDescription() {

return Description;

}

public void setDescription(String description) {

Description = description;

}

public String getUrl() {

return Url;

}

public void setUrl(String url) {

Url = url;

}

public String getPicUrl() {

return PicUrl;

}

public void setPicUrl(String picUrl) {

PicUrl = picUrl;

}

public String getMediaId() {

return MediaId;

}

public void setMediaId(String mediaId) {

MediaId = mediaId;

}

public String getEventKey() {

return EventKey;

}

public void setEventKey(String eventKey) {

EventKey = eventKey;

}

public String getTicket() {

return Ticket;

}

public void setTicket(String ticket) {

Ticket = ticket;

}

public String getLatitude() {

return Latitude;

}

public void setLatitude(String latitude) {

Latitude = latitude;

}

public String getLongitude() {

return Longitude;

}

public void setLongitude(String longitude) {

Longitude = longitude;

}

public String getPrecision() {

return Precision;

}

public void setPrecision(String precision) {

Precision = precision;

}

public String getEvent() {

return Event;

}

public void setEvent(String event) {

Event = event;

}

public String getMsgId() {

return MsgId;

}

public void setMsgId(String msgId) {

MsgId = msgId;

}

public String getToUserName() {

return ToUserName;

}

public void setToUserName(String toUserName) {

关于java微信接口开发和java调用微信接口的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

The End

发布于:2022-11-28,除非注明,否则均为首码项目网原创文章,转载请注明出处。