精华内容
下载资源
问答
  • java微信小程序开发

    2018-03-22 14:27:11
    java开发小程序源码,有需要的可以下载学习交流。多个案例
  • 详解java微信小程序开发中加密解密算法一、概述微信推出了小程序,很多公司的客户端应用不仅具有了APP、H5、还接入了小程序开发。但是,小程序中竟然没有提供Java版本的加密数据解密算法。这着实让广大的Java开发...

    详解java微信小程序开发中加密解密算法

    一、概述

    微信推出了小程序,很多公司的客户端应用不仅具有了APP、H5、还接入了小程序开发。但是,小程序中竟然没有提供Java版本的加密数据解密算法。这着实让广大的Java开发人员蛋疼。

    微信小程序提供的加密数据解密算法链接

    我们下载的算法示例如下:

    木有Java!! 木有Java!! 木有Java!!

    那么如何解决这个问题,我们一起来实现Java版本的微信小程序加密数据解密算法。

    二、实现Java版本的微信小程序加密数据解密算法

    1、创建项目

    这里,我们创建一个Maven工程,具体创建步骤略。

    2、配置pom.xml

    我们在pom.xml中加入如下配置。

    org.bouncycastle

    bcprov-jdk16

    1.46

    commons-codec

    commons-codec

    1.4

    net.sf.json-lib

    json-lib

    2.2.3

    jdk15

    3、实现AES类

    package com.chwl.medical.crypto.wx;

    import java.security.AlgorithmParameters;

    import java.security.InvalidAlgorithmParameterException;

    import java.security.InvalidKeyException;

    import java.security.Key;

    import java.security.NoSuchAlgorithmException;

    import java.security.NoSuchProviderException;

    import java.security.Security;

    import javax.crypto.BadPaddingException;

    import javax.crypto.Cipher;

    import javax.crypto.IllegalBlockSizeException;

    import javax.crypto.NoSuchPaddingException;

    import javax.crypto.spec.IvParameterSpec;

    import javax.crypto.spec.SecretKeySpec;

    import org.bouncycastle.jce.provider.BouncyCastleProvider;

    /**

    * AES加密

    * @author liuyazhuang

    *

    */

    public class AES {

    public static boolean initialized = false;

    /**

    * AES解密

    *

    * @param content

    * 密文

    * @return

    * @throws InvalidAlgorithmParameterException

    * @throws NoSuchProviderException

    */

    public byte[] decrypt(byte[] content, byte[] keyByte, byte[] ivByte) throws InvalidAlgorithmParameterException {

    initialize();

    try {

    Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding");

    Key sKeySpec = new SecretKeySpec(keyByte, "AES");

    cipher.init(Cipher.DECRYPT_MODE, sKeySpec, generateIV(ivByte));// 初始化

    byte[] result = cipher.doFinal(content);

    return result;

    } catch (NoSuchAlgorithmException e) {

    e.printStackTrace();

    } catch (NoSuchPaddingException e) {

    e.printStackTrace();

    } catch (InvalidKeyException e) {

    e.printStackTrace();

    } catch (IllegalBlockSizeException e) {

    e.printStackTrace();

    } catch (BadPaddingException e) {

    e.printStackTrace();

    } catch (NoSuchProviderException e) {

    // TODO Auto-generated catch block

    e.printStackTrace();

    } catch (Exception e) {

    // TODO Auto-generated catch block

    e.printStackTrace();

    }

    return null;

    }

    public static void initialize() {

    if (initialized)

    return;

    Security.addProvider(new BouncyCastleProvider());

    initialized = true;

    }

    // 生成iv

    public static AlgorithmParameters generateIV(byte[] iv) throws Exception {

    AlgorithmParameters params = AlgorithmParameters.getInstance("AES");

    params.init(new IvParameterSpec(iv));

    return params;

    }

    }

    4、实现WxPKCS7Encoder类

    package com.chwl.medical.crypto.wx;

    import java.nio.charset.Charset;

    import java.util.Arrays;

    /**

    * 微信小程序加解密

    * @author liuyazhuang

    *

    */

    public class WxPKCS7Encoder {

    private static final Charset CHARSET = Charset.forName("utf-8");

    private static final int BLOCK_SIZE = 32;

    /**

    * 获得对明文进行补位填充的字节.

    *

    * @param count

    * 需要进行填充补位操作的明文字节个数

    * @return 补齐用的字节数组

    */

    public static byte[] encode(int count) {

    // 计算需要填充的位数

    int amountToPad = BLOCK_SIZE - (count % BLOCK_SIZE);

    if (amountToPad == 0) {

    amountToPad = BLOCK_SIZE;

    }

    // 获得补位所用的字符

    char padChr = chr(amountToPad);

    String tmp = new String();

    for (int index = 0; index < amountToPad; index++) {

    tmp += padChr;

    }

    return tmp.getBytes(CHARSET);

    }

    /**

    * 删除解密后明文的补位字符

    *

    * @param decrypted

    * 解密后的明文

    * @return 删除补位字符后的明文

    */

    public static byte[] decode(byte[] decrypted) {

    int pad = decrypted[decrypted.length - 1];

    if (pad < 1 || pad > 32) {

    pad = 0;

    }

    return Arrays.copyOfRange(decrypted, 0, decrypted.length - pad);

    }

    /**

    * 将数字转化成ASCII码对应的字符,用于对明文进行补码

    *

    * @param a

    * 需要转化的数字

    * @return 转化得到的字符

    */

    public static char chr(int a) {

    byte target = (byte) (a & 0xFF);

    return (char) target;

    }

    }

    5、实现WXCore类

    这个类主要是对具体算法的封装,统一对外提供方法。

    package com.chwl.medical.crypto.wx;

    import org.apache.commons.codec.binary.Base64;

    import net.sf.json.JSONObject;

    /**

    * 封装对外访问方法

    * @author liuyazhuang

    *

    */

    public class WXCore {

    private static final String WATERMARK = "watermark";

    private static final String APPID = "appid";

    /**

    * 解密数据

    * @return

    * @throws Exception

    */

    public static String decrypt(String appId, String encryptedData, String sessionKey, String iv){

    String result = "";

    try {

    AES aes = new AES();

    byte[] resultByte = aes.decrypt(Base64.decodeBase64(encryptedData), Base64.decodeBase64(sessionKey), Base64.decodeBase64(iv));

    if(null != resultByte && resultByte.length > 0){

    result = new String(WxPKCS7Encoder.decode(resultByte));

    JSONObject jsonObject = JSONObject.fromObject(result);

    String decryptAppid = jsonObject.getJSONObject(WATERMARK).getString(APPID);

    if(!appId.equals(decryptAppid)){

    result = "";

    }

    }

    } catch (Exception e) {

    result = "";

    e.printStackTrace();

    }

    return result;

    }

    public static void main(String[] args) throws Exception{

    String appId = "wx4f4bc4dec97d474b";

    String encryptedData = "CiyLU1Aw2KjvrjMdj8YKliAjtP4gsMZMQmRzooG2xrDcvSnxIMXFufNstNGTyaGS9uT5geRa0W4oTOb1WT7fJlAC+oNPdbB+3hVbJSRgv+4lGOETKUQz6OYStslQ142dNCuabNPGBzlooOmB231qMM85d2/fV6ChevvXvQP8Hkue1poOFtnEtpyxVLW1zAo6/1Xx1COxFvrc2d7UL/lmHInNlxuacJXwu0fjpXfz/YqYzBIBzD6WUfTIF9GRHpOn/Hz7saL8xz+W//FRAUid1OksQaQx4CMs8LOddcQhULW4ucetDf96JcR3g0gfRK4PC7E/r7Z6xNrXd2UIeorGj5Ef7b1pJAYB6Y5anaHqZ9J6nKEBvB4DnNLIVWSgARns/8wR2SiRS7MNACwTyrGvt9ts8p12PKFdlqYTopNHR1Vf7XjfhQlVsAJdNiKdYmYVoKlaRv85IfVunYzO0IKXsyl7JCUjCpoG20f0a04COwfneQAGGwd5oa+T8yO5hzuyDb/XcxxmK01EpqOyuxINew==";

    String sessionKey = "tiihtNczf5v6AKRyjwEUhQ==";

    String iv = "r7BXXKkLb8qrSNn05n0qiA==";

    System.out.println(decrypt(appId, encryptedData, sessionKey, iv));

    }

    }

    三、测试

    1、运行Java版微信小程序加密数据解密算法

    这里我们就直接运行WXcore类的main方法,这里的测试数据都是从Python版微信小程序加密数据解密算法的示例程序中提出来的。我们的运行结果如下:

    代码如下:

    {"openId":"oGZUI0egBJY1zhBYw2KhdUfwVJJE","nickName":"Band","gender":1,"language":"zh_CN","city":"Guangzhou","province":"Guangdong","country":"CN","avatarUrl":"http://wx.qlogo.cn/mmopen/vi_32/aSKcBBPpibyKNicHNTMM0qJVh8Kjgiak2AHWr8MHM4WgMEm7GFhsf8OYrySdbvAMvTsw3mo8ibKicsnfN5pRjl1p8HQ/0","unionId":"ocMvos6NjeKLIBqg5Mr9QjxrP1FA","watermark":{"timestamp":1477314187,"appid":"wx4f4bc4dec97d474b"}}

    2、运行Python版微信小程序加密数据解密算法

    这里我们在python环境中直接运行微信官方提供的Python版小程序加密数据解密算法,结果如下:

    代码如下:

    {u'province': u'Guangdong', u'openId': u'oGZUI0egBJY1zhBYw2KhdUfwVJJE', u'language': u'zh_CN', u'city': u'Guangzhou', u'gender': 1, u'avatarUrl': u'http://wx.qlogo.cn/mmopen/vi_32/aSKcBBPpibyKNicHNTMM0qJVh8Kjgiak2AHWr8MHM4WgMEm7GFhsf8OYrySdbvAMvTsw3mo8ibKicsnfN5pRjl1p8HQ/0', u'watermark': {u'timestamp': 1477314187, u'appid': u'wx4f4bc4dec97d474b'}, u'country': u'CN', u'nickName': u'Band', u'unionId': u'ocMvos6NjeKLIBqg5Mr9QjxrP1FA'}

    通过对比以上结果可知,我们自行使用Java实现的Java版微信小程序加密数据解密算法与微信官方提供的Python版小程序加密数据解密算法结果一致。

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。

    微信小程序登录状态java后台解密

    一、登录流程图

    二、微信小程序端

    doLogin:function(callback = () =>{}){

    let that = this;

    wx.login({

    success:function(loginRes){

    if(loginRes){

    //获取用户信息

    wx.getUserInfo({

    withCredentials:true,//非必填 默认为true

    success:function(infoRes){

    console.log(infoRes,'>>>');

    //请求服务端的登录接口

    wx.request({

    url: api.loginUrl,

    data:{

    code:loginRes.code,//临时登录凭证

    rawData:infoRes.rawData,//用户非敏感信息

    signature:infoRes.signature,//签名

    encrypteData:infoRes.encryptedData,//用户敏感信息

    iv:infoRes.iv//解密算法的向量

    },

    success:function(res){

    console.log('login success');

    res = res.data;

    if(res.result==0){

    that.globalData.userInfo = res.userInfo;

    wx.setStorageSync('userInfo',JSON.stringify(res.userInfo));

    wx.setStorageSync('loginFlag',res.skey);

    console.log("skey="+res.skey);

    callback();

    }else{

    that.showInfo('res.errmsg');

    }

    },

    fail:function(error){

    //调用服务端登录接口失败

    // that.showInfo('调用接口失败');

    console.log(error);

    }

    });

    }

    });

    }else{

    }

    }

    });

    }

    微信小程序端发起登录请求,携带的参数主要有:

    code:loginRes.code,//临时登录凭证

    rawData:infoRes.rawData,//用户非敏感信息

    signature:infoRes.signature,//签名

    encrypteData:infoRes.encryptedData,//用户敏感信息

    iv:infoRes.iv//解密算法的向量

    需要的数据主要有:

    result、userInfo和skey

    result用来判断是否登录成功,userInfo是用户的一些信息,保存在缓存中,不用每次都从后台获取,skey是用户登录态标识,也放在缓存中,如果skey存在就直接登录,维护用户的登录状态,具有时效性

    三、Java后台

    @ResponseBody

    @RequestMapping("/login")

    public Map doLogin(Model model,

    @RequestParam(value = "code",required = false) String code,

    @RequestParam(value = "rawData",required = false) String rawData,

    @RequestParam(value = "signature",required = false) String signature,

    @RequestParam(value = "encrypteData",required = false) String encrypteData,

    @RequestParam(value = "iv",required = false) String iv){

    log.info( "Start get SessionKey" );

    Map map = new HashMap( );

    System.out.println("用户非敏感信息"+rawData);

    JSONObject rawDataJson = JSON.parseObject( rawData );

    System.out.println("签名"+signature);

    JSONObject SessionKeyOpenId = getSessionKeyOrOpenId( code );

    System.out.println("post请求获取的SessionAndopenId="+SessionKeyOpenId);

    String openid = SessionKeyOpenId.getString("openid" );

    String sessionKey = SessionKeyOpenId.getString( "session_key" );

    System.out.println("openid="+openid+",session_key="+sessionKey);

    User user = userService.findByOpenid( openid );

    //uuid生成唯一key

    String skey = UUID.randomUUID().toString();

    if(user==null){

    //入库

    String nickName = rawDataJson.getString( "nickName" );

    String avatarUrl = rawDataJson.getString( "avatarUrl" );

    String gender = rawDataJson.getString( "gender" );

    String city = rawDataJson.getString( "city" );

    String country = rawDataJson.getString( "country" );

    String province = rawDataJson.getString( "province" );

    user = new User();

    user.setUid( openid );

    user.setCreateTime( new Date( ) );

    user.setSessionkey( sessionKey );

    user.setUbalance( 0 );

    user.setSkey( skey );

    user.setUaddress( country+" "+province+" "+city );

    user.setUavatar( avatarUrl );

    user.setUgender( Integer.parseInt( gender ) );

    user.setUname( nickName );

    user.setUpdateTime( new Date( ) );

    userService.insert( user );

    }else {

    //已存在

    log.info( "用户openid已存在,不需要插入" );

    }

    //根据openid查询skey是否存在

    String skey_redis = (String) redisTemplate.opsForValue().get( openid );

    if(StringUtils.isNotBlank( skey_redis )){

    //存在 删除 skey 重新生成skey 将skey返回

    redisTemplate.delete( skey_redis );

    }

    // 缓存一份新的

    JSONObject sessionObj = new JSONObject( );

    sessionObj.put( "openId",openid );

    sessionObj.put( "sessionKey",sessionKey );

    redisTemplate.opsForValue().set( skey,sessionObj.toJSONString() );

    redisTemplate.opsForValue().set( openid,skey );

    //把新的sessionKey和oppenid返回给小程序

    map.put( "skey",skey );

    map.put( "result","0" );

    JSONObject userInfo = getUserInfo( encrypteData, sessionKey, iv );

    System.out.println("根据解密算法获取的userInfo="+userInfo);

    userInfo.put( "balance",user.getUbalance() );

    map.put( "userInfo",userInfo );

    return map;

    }

    获取openid和sessionKey方法

    public static JSONObject getSessionKeyOrOpenId(String code){

    //微信端登录code

    String wxCode = code;

    String requestUrl = "https://api.weixin.qq.com/sns/jscode2session";

    Map requestUrlParam = new HashMap( );

    requestUrlParam.put( "appid","你的小程序appId" );//小程序appId

    requestUrlParam.put( "secret","你的小程序appSecret" );

    requestUrlParam.put( "js_code",wxCode );//小程序端返回的code

    requestUrlParam.put( "grant_type","authorization_code" );//默认参数

    //发送post请求读取调用微信接口获取openid用户唯一标识

    JSONObject jsonObject = JSON.parseObject( UrlUtil.sendPost( requestUrl,requestUrlParam ));

    return jsonObject;

    }

    解密用户敏感数据获取用户信息

    public static JSONObject getUserInfo(String encryptedData,String sessionKey,String iv){

    // 被加密的数据

    byte[] dataByte = Base64.decode(encryptedData);

    // 加密秘钥

    byte[] keyByte = Base64.decode(sessionKey);

    // 偏移量

    byte[] ivByte = Base64.decode(iv);

    try {

    // 如果密钥不足16位,那么就补足. 这个if 中的内容很重要

    int base = 16;

    if (keyByte.length % base != 0) {

    int groups = keyByte.length / base + (keyByte.length % base != 0 ? 1 : 0);

    byte[] temp = new byte[groups * base];

    Arrays.fill(temp, (byte) 0);

    System.arraycopy(keyByte, 0, temp, 0, keyByte.length);

    keyByte = temp;

    }

    // 初始化

    Security.addProvider(new BouncyCastleProvider());

    Cipher cipher = Cipher.getInstance("AES/CBC/PKCS7Padding","BC");

    SecretKeySpec spec = new SecretKeySpec(keyByte, "AES");

    AlgorithmParameters parameters = AlgorithmParameters.getInstance("AES");

    parameters.init(new IvParameterSpec(ivByte));

    cipher.init( Cipher.DECRYPT_MODE, spec, parameters);// 初始化

    byte[] resultByte = cipher.doFinal(dataByte);

    if (null != resultByte && resultByte.length > 0) {

    String result = new String(resultByte, "UTF-8");

    return JSON.parseObject(result);

    }

    } catch (NoSuchAlgorithmException e) {

    log.error(e.getMessage(), e);

    } catch (NoSuchPaddingException e) {

    log.error(e.getMessage(), e);

    } catch (InvalidParameterSpecException e) {

    log.error(e.getMessage(), e);

    } catch (IllegalBlockSizeException e) {

    log.error(e.getMessage(), e);

    } catch (BadPaddingException e) {

    log.error(e.getMessage(), e);

    } catch (UnsupportedEncodingException e) {

    log.error(e.getMessage(), e);

    } catch (InvalidKeyException e) {

    log.error(e.getMessage(), e);

    } catch (InvalidAlgorithmParameterException e) {

    log.error(e.getMessage(), e);

    } catch (NoSuchProviderException e) {

    log.error(e.getMessage(), e);

    }

    return null;

    }

    四、流程

    1.小程序端发起请求并携带主要参数

    2.java后台接到/login请求后,根据code去调用微信接口获取用户唯一标识openid和sessionKey

    3.根据openid查询mysql数据库,判断该用户是否存在,如果不存在将用户非敏感信息和其他初始化数据存入到数据库中,如果已存在,不操作

    4.根据openid查询redis数据库,判断openid对应的skey是否存在,如果存在则删除原来老的skey以及对应的openid和sessionKey

    5.通过uuid生成唯一的skey,用openid做键,skey做值,存入到redis中

    6.然后把skey做键,openid和sessionKey的json串做值也重新存入到redis中

    7.根据解密算法,参数有encryptedData、sessionKey和iv,获取用户信息userInfo,如果userInfo字段不满足需要,可通过userInfo.put( “balance”,user.getUbalance() );添加所需要的字段和值

    8.将微信小程序需要的数据封装到map中,返回给小程序端

    map.put( "skey",skey );

    map.put( "result","0" );

    map.put( "userInfo",userInfo );

    return map;

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。

    以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

    展开全文
  • JAVA 微信小程序开发资源总结,来自于各位大神的总结,收集供大家参考。

    有兴趣学习微信小程序开发的可以关注简书专题 微信小程序开发

    这篇文章只是资源的搬运工, 感谢各位大神的无私奉献。 
    由于微信小程序只邀请了200个大V内测,但是这些大V好多都是不写代码的CTO了,让真正想学习些代码的灰常着急。 
    俗话说高手在民间,没过多久就有大神把文档和0.7的破解版发出来了。但是下午,微信就发布了0.9版本,封杀了之前破解的。经过大神们的不懈努力,0.9版本也在昨晚攻陷了。

    文档:

    官方地址(目前内测用户才能查看文档) https://mp.weixin.qq.com/wxopen/wawiki

    开发文档

    http://wxopen.notedown.cn/

    介绍 http://wxopen.notedown.cn/introduction 
    设计 http://wxopen.notedown.cn/design 
    运营 http://wxopen.notedown.cn/product 
    开发 http://wxopen.notedown.cn/api

    相关资源

    破解步骤

    Mac测试可用,Windows测试可用

    1. 下载开发工具,并安装(注意:一定要安装0.9版本
    2. 打开『微信Web开发者工具』的程序目录 
      • Windows:使用资源管理器查看
      • Mac:右键点击图标,选择『显示包内容』
    3. 进入程序目录后,替换以下文件(只需要替换0.9版本里的,0.7版本用来登陆):

      • Windows:
      • \package.nw\app\dist\components\create\createstep.js
      • \package.nw\app\dist\stroes\projectStores.js
      • Mac:
      • /Resources/app.nw/app/dist/components/create/createstep.js
      • /Resources/app.nw/app/dist/stroes/projectStores.js

      注意,这里微信工程师拼写错了,是stroes没错!!!

      替换的文件点击这里下载

    4. Good luck

    扫码无法登录问题 please bind your wechat account to the appid first

    先使用0.7版本[Windows|Mac]的进行扫码登陆 
    登陆成功后,再用0.9版本打开就直接进入了

    使用教程

    1. 运行『微信Web开发者工具』
    2. 通过微信扫描二维码
    3. 创建项目 
      • AppID:随便填
      • 项目名称:随便填
      • 本地开发目录:选择一个目录
    4. 点击「添加项目」 
      • 此时如果出错,先退出再重进
      • 此时,能够看到项目列表了
    5. 打开项目
    6. 开始开发
    7. Good luck

    常见问题

    1. 找不到所要替换的文件 
      • 问题原因:开发工具版本不正确,老版本不支持
      • 解决方案:确保下载的程序版本在0.9.092100以上
    2. Failed to load resource: net::ERR_NAME_NOT_RESOLVED http://1709827360.appservice.open.weixin.qq.com/appservice 
      • 问题原因:通常是由于系统设置了代理如Shadowsocks等。
      • 解决方案:关闭代理,或者依次点击工具栏“动作”-“设置”,选择“不使用任何代理,勾选后直连网络”。
    3. 修复asdebug.js报错 
      • 问题原因:TypeError: Cannot read property ‘MaxRequestConcurrent’ of undefined
      • 解决方案:替换 /Resources/app.nw/app/dist/weapp/appservice/asdebug.js
    4. 扫码登录失败 

    工具截图

    IDE

    Demo导入方式

    打开“微信web开发者工具” –>添加项目–>填写AppID(随便填)、项目名称(随便填),选择本地开发目录(Demo存放地址)–>点击“添加项目” 即可

    相关链接

    https://github.com/Notedown-cn/wxopen 
    https://github.com/gavinkwoe/weapp-ide-crack 
    http://www.diycode.cc/topics/308 
    http://www.geek-zoo.com


    展开全文
  • 1.微信小程序开发:http://blog.csdn.net/column/details/13721.html?&page=1 2.微信小程序栏目:http://blog.csdn.net/column/details/14653.html?&page=2 3. ...
    展开全文
  • 微信小程序开发【前端+后端(java)】

    万次阅读 多人点赞 2018-07-13 22:19:46
    现在微信小程序越来越火了,相信不少人都通过各种途径学习过微信小程序或者尝试开发,作者就是曾经由于兴趣了解开发微信小程序,最终自己的毕业设计也是开发一个微信小程序。所以现在用这篇博客记录我之前开发的...
    1. 前言
      现在微信小程序越来越火了,相信不少人都通过各种途径学习过微信小程序或者尝试开发,作者就是曾经由于兴趣了解开发过微信小程序,最终自己的毕业设计也是开发一个微信小程序。所以现在用这篇博客记录我之前开发的一些经验和一些心得吧。

    2. 主要内容
      springboot后端架构构建
      小程序项目构建
      小程序api调用
      后台resetful接口编写
      小程序调用后台接口
      免费的https申请
      linux下部署上线

    3. 微信小程序项目构建
      这些基础的东西我就不过多介绍,大家在刚开始开发的时候一般都没有自己的服务器及域名,所以大家在本地编写的时候,在“详细”下的“项目设置”里面将“不校验域名安全性”勾选。这里写图片描述
      至于微信小程序的组件,即前端页面的开发希望大家耐住寂寞认真在微信开发平台上,组件https://developers.weixin.qq.com/miniprogram/dev/component/及api:https://developers.weixin.qq.com/miniprogram/dev/api/

    4. 后端详解
      我在后端编写主要是用java,当然对其他开发语言熟悉的也可以使用其他语言开发后端。现在我就java编写后端api的讲解。主要框架springboot,开发工具myeclipse,服务器阿里云服务器。
      创建一个maven项目,导入相关依赖:
      pom.xml依赖

        <!-- 统一版本控制 -->
    	<parent>
    		<groupId>org.springframework.boot</groupId>
    		<artifactId>spring-boot-starter-parent</artifactId>
    		<version>1.5.9.RELEASE</version>
    	</parent>
    	<dependencies>
    		<!-- freemarker渲染页面 -->
    		<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-freemarker -->
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-freemarker</artifactId>
    		</dependency>
    
    		<!-- spring boot 核心 -->
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-web</artifactId>
    		</dependency>
    
    		<!-- springboot整合jsp -->
    		<!-- tomcat 的支持. -->
    		<dependency>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-starter-web</artifactId>
    			<exclusions>
    				<exclusion>
    					<groupId>org.springframework.boot</groupId>
    					<artifactId>spring-boot-starter-tomcat</artifactId>
    				</exclusion>
    			</exclusions>
    		</dependency>
    
    		<dependency>
    			<groupId>org.apache.tomcat.embed</groupId>
    			<artifactId>tomcat-embed-jasper</artifactId>
    		</dependency>
    	</dependencies>
    

    在配置文件src/main/resources/下创建application.properties文件可以修改一些配置参数等。

    #jsp支持
    spring.mvc.view.suffix=.jsp
    spring.mvc.view.prefix=/WEB-INF/jsp/
    #this is set port
    #server.port=80
    server.port=443
    #添加ssl证书
    #ssl证书文件名
    server.ssl.key-store=classpath:xxxxxxx.pfx
    server.ssl.key-store-password=xxxxxxxx
    server.ssl.keyStoreType=xxxxxxxx
    

    在实际项目中可能涉及数据库,还要整合mybatis,在文章中,我仅仅做测试就不做使用数据库的测试。
    首先创建springboot的入口程序:app.class下面贴上代码:

    @ComponentScan(basePackages= "com.bin")//添加扫包@ComponentScan(basePackages= "")
    @EnableAutoConfiguration
    public class App{
    
    	//启动springboot
    	public static void main(String[] args) {
    		SpringApplication.run(App.class, args);
    	}
    }
    

    启动项目时直接右击run即可。
    在写一个测试的controller进行微信小程序与java后端实现通信,controller代码如下:

    @RestController
    @SpringBootApplication
    public class ControllerText {
    	
    	@RequestMapping("getUser")
    	public Map<String, Object> getUser(){
    		System.out.println("微信小程序正在调用。。。");
    		Map<String, Object> map = new HashMap<String, Object>();
    		List<String> list = new ArrayList<String>();
     		list.add("zhangsan");
     		list.add("lisi");
     		list.add("wanger");
     		list.add("mazi");
     		map.put("list",list);
    		System.out.println("微信小程序调用完成。。。");
    		return map;
    	}
    	
    	@RequestMapping("getWord")
    	public Map<String, Object> getText(String word){
    		Map<String, Object> map = new HashMap<String, Object>();
    		String message = "我能力有限,不要为难我";
    		if ("后来".equals(word)) {
    			message="正在热映的后来的我们是刘若英的处女作。";
    		}else if("微信小程序".equals(word)){
    			message= "想获取更多微信小程序相关知识,请更多的阅读微信官方文档,还有其他更多微信开发相关的内容,学无止境。";
    		}else if("西安工业大学".equals(word)){
    			message="西安工业大学(Xi'an Technological University)简称”西安工大“,位于世界历史名城古都西安,是中国西北地区唯一一所以兵工为特色,以工为主,理、文、经、管、法协调发展的教学研究型大学。原中华人民共和国兵器工业部直属的七所本科院校之一(“兵工七子”),陕西省重点建设的高水平教学研究型大学、陕西省人民政府与中国兵器工业集团、国防科技工业局共建高校、教育部“卓越工程师教育培养计划”试点高校、陕西省大学生创新能力培养综合改革试点学校。国家二级保密资格单位,是一所以\"军民结合,寓军于民\"的国防科研高校。";
    		}
    		map.put("message", message);
    		return map;
    	}
    	
    	@RequestMapping("")
    	public String getText(){
    		return "hello world";
    	}
    
    
    }
    

    至此简易的后端框架及测试基本完成。
    说明:@RestController与@Controller注解的区别@RestController相当于两个注解,它能实现将后端得到的数据在前端页面(网页)中以json串的形式传递。而微信小程序与后台之间的数据传递就是以json报文的形式传递。所以这就是选择springboot框架开发小程序后端的主要原因之一。可以方面我们进行小程序的后端开发。

    1. 小程序发起网络请求
      在完成了小程序的后端开发,下面进行小程序端发起网络请求。
      下面以一个简单的按钮请求数据为例:
      wxml文件
    <button bindtap='houduanButton1'>点击发起请求</button>
    <view wx:for="{{list}}">
        姓名:{{item}}
      </view>
    
    js文件
    
     /**
       * 页面的初始数据
       */
      data: {
        list: '',
        word: '',
        message:''
    
      },
      houduanButton1: function () {
        var that = this;
        wx.request({
          url: 'http://localhost:443/getUser',
          method: 'GET',
          header: {
            'content-type': 'application/json' // 默认值
          },
          success: function (res) {
            console.log(res.data)//打印到控制台
            var list = res.data.list;
            if (list == null) {
              var toastText = '数据获取失败';
              wx.showToast({
                title: toastText,
                icon: '',
                duration: 2000
              });
            } else {
              that.setData({
                list: list
              })
            }
          }
        })
      }
    

    主要调用的api就是wx.request,想知道将详细的介绍大家可以去微信公众平台
    接下来以搜索类型的请求为例:
    wxml文件:

     <input type="text" class="houduanTab_input" placeholder="请输入你要查询的内容" bindinput='houduanTab_input'></input>
      <button bindtap='houduanButton2'>查询</button>
      <view wx:if="{{message!=''}}">
        {{message}}
      </view>
    

    js文件:变量的定义见上一个js文件

    //获取输入框的内容
      houduanTab_input: function (e) {
        this.setData({
          word: e.detail.value
        })
      },
      // houduanButton2的网络请求
      houduanButton2: function () {
        var that = this;
        wx.request({
          url: 'http://localhost:443/getWord',
          data:{
            word: that.data.word
          },
          method: 'GET',
          header: {
            'content-type': 'application/json' // 默认值
          },
          success: function (res) {
            console.log(res.data)//打印到控制台
            var message = res.data.message;
            if (message == null) {
              var toastText = '数据获取失败';
              wx.showToast({
                title: toastText,
                icon: '',
                duration: 2000
              });
            } else {
              that.setData({
                message: message
              })
            }
          }
        })
      }
    

    至此已经完成了简易的微信小程序端与java后端进行通信。
    现在可以在启动后端项目在微信开发工具上进行测试。
    演示效果:
    这里写图片描述
    这里写图片描述
    所以至此已经完成了小程序的前后端通信。

    1. https申请
      其实也不算什么申请,在购买域名之后可以申请免费的ssl证书,在前面的配置文件application.properties中有证书的配置,将证书的pfx文件直接添加到后端项目下即可。
    2. 购买服务器部署后端api代码
      对于springboot项目,本人建议打jar,直接在服务器上部署即可,在服务器上只需要安装对应版本的jdk即可。项目部署命令:
      我购买的是阿里云的轻量级应用服务器部署的。比较划算吧。
    运行命令: nohup java -jar helloworld.jar &
    

    nohup的意思不挂服务,常驻的意思,除非云服务器重启,那就没法了;最后一个&表示执行命令后要生成日志文件nohup.out。
    当然还可以使用java -jar helloworld.jar

    源码:链接: https://pan.baidu.com/s/1PfByFfEgqkVALcc3PRhn9w 提取码: c7yf

    结束语:由于时间篇幅问题,本人介绍的内容很有限,希望对这方面有兴趣的你能有帮助。共同进步。
    觉得有帮助,给个赞赏吧。给赞赏的优先同意qq或者微信,问问题秒回复等[滑稽],谢谢老铁。
    在这里插入图片描述

    展开全文
  • //小程序调用wx.login返回的code paramMap.put("grant_type", wechatToken.getGrantType()); //默认参数 authorization_code PrintWriter out = null; BufferedReader in = null; String result = ""; String param...
  • 开发微信小程序支付的功能前,我们先熟悉下微信小程序支付的业务流程图:不熟悉流程的建议还是仔细阅读微信官方的开发者文档。一,准备工作事先需要申请企业版小程序,并开通“微信支付”(即商户功能)。并获取一下...
  • java微信小程序支付

    2018-06-27 10:54:40
    java开发微信小程序的支付代码,避免开发小程序踩坑。
  • 微信小程序 开发中遇到问题总结1.由于小程序wx.request()方法是异步的,在app.js执行ajax后,各分页加载app.js的全局数据时,无法按顺序加载。例://app.jsApp({ajax:function(){let that = this;wx.request({url: '...
  • 最近接了一个微信小程序的活,想象中微信小程序应该跟普通的网站开发差不多,实际上就前端来说确实差不多,但是还是遇到不少蛋疼的问题,所以这里记录一下,希望对后来人有所启示。服务器端方面:服务器端是用Java写...
  • 微信小程序开发

    千人学习 2019-04-25 20:09:19
    本课程主要介绍如何开发微信小程序,是一门比较基础入门的微信小程序开发课程,... 本套课程需要的一些前期准备为需要下载好微信小程序开发工具,后端需要myeclipse开发工具以及安装jdk8及tomcat8,后端开发主要为java
  • 最近,经历多个微信小程序支付以及小程序退款实战项目,今天编者经过整理,把小程序申请退款的实战项目案例分享给大家,希望能让大家借鉴,在项目开发中少走弯路。   小程序处理退款前提需安装商户安全证书: ...
  • 最近小程序越来越火,很多开发微信小程序这块,后面给大家讲解下java作为后台开发语言如何开发微信小程序 首先后台采用springboot mybatis作为框架 小程序这块用weui组件 开发小程序的第一步其实就是授权登陆 界面...
  • java微信小程序商城

    2018-09-05 21:26:47
    专门针对微信服务号开发的一套微信商城,微信分销商城,支持商品多规格,支持按地区设置邮费,支持限时打折,订单返现,满减送,满包邮,支持订单打印,订单打印模板自定义,发货单打印,发货单打印模板自定义,支持...
  • 原标题:揭秘微信小程序开发流程除了众所周知的微信小程序之外,目前还有百度小程序,头条小程序,抖音小程序等。该小程序具有体积小、运行速度快、无需安装、不占用手机内存、即用即走的特点。如今,越来越多的用户...
  • 登录流程时序登录流程时序 具体的登录说明查看 小程序官方API项目的结构图: springboot项目搭建使用idea作为开发工具,由gradle构建项目,搭建springboot项目,对这块儿不熟悉的可以自行去学习,此处不多赘述。...
  • Java微信小程序母婴用品商城 大学生毕业设计教学视频 讲解如何发布小程序商城的后台、如何设置、如何发布小程序和设置小程序、功能演示包含界面和开发讲解;主要讲解移动商城首页、商城分类、商城购物车、产品分类、...
  • 完成注册点击立即注册选择小程序按要求填写注册信息2、下载微信开发者工具登录微信小程序账号 ->点击文档-> 点击工具 ->点击微信开发者工具 -> 选择合适自己电脑的开发者工具下载下来 -> 安装...
  • 1、打开微信公众平台官网:https://mp.weixin.qq.com/ 右上角点击“立即​注册”; 选择帐号类型; ...2、填写邮箱,登录您的邮箱,查看激活邮件,填写邮箱验证码激活;...2、查看小程序appid和密钥; ...
  • 1、复制粘贴永远不是自己的。我是一名小白,做的有些粗糙,希望对大家有所帮助! 谢谢我借鉴的几篇博客!(敲一敲总会有!) JAVA后台: (1)首先奉献上我的工程目录 ...2、小程序部分 .wxml .js ...
  • 我的java微信小程序后台

    万次阅读 热门讨论 2017-07-04 19:59:25
    wechat-master目录是小程序的文件,为了方便就和jsp放在了一起,用微信小程序开发工具导入,换掉request地址 其中openid的使用有些安全性问题,因为小程序不支持cookie,我把openid放在了Storage
  • 针对微信小程序的支付和退款的服务端功能开发java语言
  • 选课微信小程序开发 java

    千次阅读 热门讨论 2020-05-29 17:22:35
    微信小程序 2.功能介绍 后台管理 学生管理 课程管理 类型管理 选课管理 操作中心 管理员中心 导入导出学生 微信小程序端 学生端 查看课程 选课 查看选课课程表 个人中心 管理员 ...
  • 开发小程序之前,确保你的小程序开通了微信支付(开通申请要求小程序已发布上线),详情参考微信支付开发文档。、 地址:https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_11&index=2 调用...
  • 讲解如何发布小程序商城的后台、如何设置、如何发布小程序和设置小程序、功能演示 包含界面和开发讲解;...请购买套餐,套餐包含 ...10-微信小程序javaweb商城接口源代码 11-微信小程序商城实战  
  • Springboot+Mybatis+Mysql+ 微信小程序+Mpvue 1、小程序展示 2、功能介绍 用户第一次使用小程序 用户授权 上传视频和图片 设置密码和有效期 分享给微信好友 输入密码提取资料 下载资料 个人...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 1,717
精华内容 686
关键字:

java微信小程序开发

java 订阅
微信小程序 订阅