2021-04-29 微信登录简易版

news/2024/11/30 9:36:23/

 

我爱java系列---【springboot整合微信扫码登陆】

1.pom.xml

复制代码

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.6.RELEASE</version>
        <relativePath/>
    </parent>
    <modelVersion>4.0.0</modelVersion>
    <artifactId>wxlogin-web</artifactId>
    <description>二维码登录功能demo</description>
    <packaging>war</packaging>
    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <!-- 日志 -->
        <slf4j.version>1.7.25</slf4j.version>
        <log4j2.version>2.7</log4j2.version>
        <!-- 异步日志 -->
        <disruptor.version>3.2.0</disruptor.version>
        <!--fastjson工具类 -->
        <fastjson.version>1.2.45</fastjson.version>
    </properties>
    <dependencies>
        <!-- https://mvnrepository.com/artifact/com.alibaba/fastjson -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.68</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
            <exclusions>
                <exclusion>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-starter-logging</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-log4j2</artifactId>
        </dependency>
        <!-- Log4j2 异步支持 -->
        <dependency>
            <groupId>com.lmax</groupId>
            <artifactId>disruptor</artifactId>
            <version>${disruptor.version}</version>
        </dependency>
        <!-- Apache Commons Logging 1.x接口的日志输出转向log4j2输出 -->
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-jcl</artifactId>
        </dependency>
        <!-- 集成测试 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
    </dependencies>
</project>

复制代码

2.前端代码login.html

复制代码

<!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8"/>
    <title>登录</title>
</head>
<body>
<!--登录框-->
<div >
    <form class="login-form">
        <!--二维码登录-->
        <div id="weixin"></div>
    </form>
</div>

 

<!--微信官方提供的生成二维码的js-->
<script src="http://res.wx.qq.com/connect/zh_CN/htmledition/js/wxLogin.js"></script>
</body> 

<script>
var obj = new WxLogin({
          self_redirect:true,
          id:"weixin",
          appid: "wx7287a60bb700fd21", #微信开放平台中申请的appid
          scope: "snsapi_login", #固定参数,可以参照微信开放平台中的文档
          redirect_uri: "http://www.txjava.cn/login" #注意:后台在host文件中添加:“127.0.0.1   www.txjava.cn”,后台springboot项目的端口号为80
          });
</script>
</html>

复制代码

3.LoginController.java

复制代码

@Controller
@RequestMapping("/login")
@Slf4j
public class LoginController {
    @Autowired
    private RestTemplate restTemplate;

    @GetMapping
    public void login(HttpServletRequest request, HttpServletResponse response) {
        //获取到code值
        String code = request.getParameter("code");
        //判断
        if (code == null) {
            throw new RuntimeException("用户禁止授权");
        }
        //获取到了code值,回调没有问题
        //定义地址
        String token_url = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=wx7287a60bb700fd21&secret=1ef8755f92bebae8ad7bab432ba29cbf&code="
                + code + "&grant_type=authorization_code";
        //发送请求
        String json = restTemplate.getForObject(token_url, String.class);
        WxToken token = parseObject(json, WxToken.class);
        //获取到接口调用凭证
        //获取个人信息
        String user_url = "https://api.weixin.qq.com/sns/userinfo?access_token="+token.getAccess_token()+"&openid="+token.getOpenid();
        String jsonStr1 = restTemplate.getForObject(user_url, String.class);
        JSONObject jsonStr = (JSONObject) JSON.parse(jsonStr1);
     //用户名
        String nickname = (String) jsonStr.get("nickname");
     //用户头像地址
        String headimgurl = (String) jsonStr.get("headimgurl");
        request.setAttribute("nickname",nickname);
        request.setAttribute("headimgurl",headimgurl);
        log.info("微信返回的用户对象:jsonStr1:{}",jsonStr);
        try {
            request.getRequestDispatcher("/main.html").forward(request, response);
        } catch (Exception e) {
            e.printStackTrace();
            throw new RuntimeException("微信扫描登陆异常");
        }
    }
}

复制代码

4.WxToken.java

复制代码

public class WxToken implements Serializable {

    private String access_token;
    private String expires_in;
    private String refresh_token;
    private String openid;
    private String scope;
    private String unionid;

    public String getAccess_token() {
        return access_token;
    }

    public void setAccess_token(String access_token) {
        this.access_token = access_token;
    }

    public String getExpires_in() {
        return expires_in;
    }

    public void setExpires_in(String expires_in) {
        this.expires_in = expires_in;
    }

    public String getRefresh_token() {
        return refresh_token;
    }

    public void setRefresh_token(String refresh_token) {
        this.refresh_token = refresh_token;
    }

    public String getOpenid() {
        return openid;
    }

    public void setOpenid(String openid) {
        this.openid = openid;
    }

    public String getScope() {
        return scope;
    }

    public void setScope(String scope) {
        this.scope = scope;
    }

    public String getUnionid() {
        return unionid;
    }

    public void setUnionid(String unionid) {
        this.unionid = unionid;
    }
}

复制代码

5.application.properties

spring.application.name=wxlogin
server.port=80


http://www.ppmy.cn/news/674602.html

相关文章

AntV - F6 小程序移动端图表组件(微信版)

AntV 蚂蚁新出的可视化组件&#xff0c;分为很多部分 官网 F6 文档链接 安装 npm install --save antv/f6-wx微信开发工具 - 工具 - 构建npm组件使用 分为图配置 / 树图配置 4. 图配置 wxml <view><f6-canvaswidth"{{canvasWidth}}"height"{{canvasH…

微信7.0版本服务器,微信7.0版本官方版

微信7.0版本官方版可以给喜欢用微信聊天的用户能够随时使用微信聊天&#xff0c;在微信7.0版本上面&#xff0c;想要怎么发表情发微信都可以&#xff0c;大家可以跟自己的微信好友通话语音视频&#xff0c;还能利用微信支付扫码等 微信7.0版本官方版相关问题 1、黑名单删除/移除…

微信 for android,微信WeChat v8.0.6 for Android 官方正式版

微信十周年之际&#xff0c;微信 WeChat 8.0.0 for Android 正式版发布&#xff0c;安卓微信8.0版本带来了一大波功能&#xff0c;例如&#xff1a;炸弹刷屏、全新动态表情、个人状态、好友封面、浮窗功能改版、好友上限提升至1万人等主要功能。 新版特性 v8.0.3 – 微信群新增…

ChatGPT有长期记忆了/ “微信版知乎”推出在即/ 高盛预测全球3亿岗位被AI取代…今日更多新鲜事在此...

日报君 发自 凹非寺量子位 | 公众号 QbitAI 大家好&#xff0c;今天是3月29日&#xff0c;周三。 量子位主办的中国AIGC产业峰会&#xff0c;圆满结束。 今天的日报君&#xff0c;来晚了一些&#xff0c;不过内容依然精彩。 孟晚舟4月1日起当值华为轮值董事长 经济观察网获悉&a…

在uniapp中使用VantUI组件库(微信版)

在uniapp中使用VantUI微信版UI库 1、安装和引入2、使用 1、安装和引入 在根目录下创建wxcomponents/vant目录,并在https://github.com/youzan/vant-weapp下载最新的zip压缩包&#xff0c;解压放入 在App.vue中引入UI样式 import "/wxcomponents/vant/dist/common/index.…

Flink stop 和 cancel停止 job 的区别

Flink 停止 job 的方式&#xff08;stop 和 cancel&#xff09; 1.Stop 方式 后边跟的任务id 是flink的任务ID&#xff0c;不是yarn的 flink stop -m 127.0.0.1:8081 357591171dfcca2eea09de 注&#xff1a;stop方式停止任务对 source 有要求&#xff0c;source必须实现了S…

基于智能分析网关的小区电动车AI检测方案设计与应用

随着人工智能技术的不断成熟与落地&#xff0c;各行各业也逐渐融入AI智能检测技术&#xff0c;尤其是在视频监控领域&#xff0c;通过AI视频智能检测与分析&#xff0c;可以大大提高视频的自动化、智能化监控能力。比如在小区的管理中&#xff0c;由电动车上楼入户引发的电梯、…

自行车

今天早上起来推自行车&#xff0c;听见边上一个女的在打电话&#xff0c;说电动车被偷了。 住的小区真不安全啊。 上班到大楼&#xff0c;忘记把自行车座拿下来了。有点担忧啊。