微信对接,获得openId

@RestController
@RequestMapping("/wx/login")
public class LoginController {

    //APPID 小程序唯一标识
    //SECRET 小程序的App secret
    private static final String APPID = "";
    private static final String SECRET = "";

    private static final String URL = "https://api.weixin.qq.com/sns/jscode2session?appid=APPID" +
            "&secret=SECRET&js_code=CODE&grant_type=authorization_code";

    @Autowired
    private UserService userService;

    @Value("${token.max.age}")
    private int tokenMaxAge;

    @Autowired
    private RedisTemplate redisTemplate;

    @GetMapping("/login")
    public Result<String> login(String username) {
        User user = userService.findByUsername(username);
        if(null == user)
            return ResultUtil.genFail(ErrorCode.USER_NOT_EXIST, "用户不存在");

        //保存token
        String tokenId=UUIDUtil.getNewValue();
        CurrentUser currentUser = buildCurrentUser(user);
        redisTemplate.opsForValue().set(Constant.KEY_REDIS_TOKEN_PREFIX+tokenId, currentUser);

        return ResultUtil.genSuccess(null,tokenId);
    }


    @GetMapping("/power")
    public Result<String> loginWx(@Valid Login login) {
        //获取openId
        String openId = getOpenId(login.getCode());

        //获取用户信息
        User user = userService.findByUsername(openId);
        if(null == user){
            user = new User();
            user.setUsername(openId);
            user.setLastLoginTime(System.currentTimeMillis()/1000);
            userService.add(user);
        } else {
            //更新用户登录信息
            userService.updateLastLoginTime(openId);
        }

        //保存token
        String tokenId=UUIDUtil.getNewValue();
        CurrentUser currentUser = buildCurrentUser(user);
        redisTemplate.opsForValue().set(Constant.KEY_REDIS_TOKEN_PREFIX+tokenId, currentUser);

        return ResultUtil.genSuccess(null,tokenId);
    }

    /**
     * 从微信获取用户openId
     * */
    private String getOpenId(String code) {
        try {
            String requestUrl = URL.replace("APPID", APPID).replace("SECRET", SECRET).replace("CODE", code);
            //获取返回的code

            HttpClient httpClient = new DefaultHttpClient();
            HttpGet httpGet = new HttpGet(requestUrl);
            ResponseHandler<String> responseHandler = new BasicResponseHandler();
            //向微信发送请求并获取response
            String response = httpClient.execute(httpGet,responseHandler);
            JsonObject jsonObject = (JsonObject) new JsonParser().parse(response);
            return jsonObject.get("openid").getAsString();
        } catch (IOException e) {
            e.printStackTrace();
            throw new MyException("获取openId失败");
        }
    }

    /**
     * 构建当前用户信息
     * */
    private CurrentUser buildCurrentUser(User user) {
        CurrentUser currentUser = new CurrentUser();
        currentUser.setUserName(user.getUsername());
        return currentUser;
    }

 

### 移动端 App 单点登录企业微信对接实现方案 #### 1. 配置准备工作 为了使 Android 应用能够通过企业微信进行单点登录,开发者需先完成必要的配置工作。具体来说,在企业微信管理后台中选择“企业微信授权登录”。此时需要在设置界面输入 Android 的应用程序签名以及包名信息[^1]。 对于进一步的功能开发,则建议查看企业微信的相关配置文档来获取详细的参数说明。特别是要关注 `agentId` 和 `appId` 这两个重要参数,它们将在后续的身份验证过程中起到关键作用[^2]。 #### 2. 获取 Code 站在用户角度考虑,应当提供一种简单直观的方式让用户发起身份验证流程。通常做法是在界面上放置一个按钮或链接(如 `<a>` 标签),当用户点击时触发向企业微信服务器发送的第一个请求——用于获得临时凭证 code。此过程涉及构建如下 URL 并引导浏览器跳转: ```plaintext https://open.weixin.qq.com/connect/oauth2/authorize?appid=YOUR_APP_ID&redirect_uri=YOUR_REDIRECT_URI&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect ``` 请注意将上述模板中的占位符替换为实际的应用 ID (`YOUR_APP_ID`) 及回调地址 (`YOUR_REDIRECT_URI`) 等必要信息[^3]。 #### 3. 处理回调与 Token 换取 一旦用户完成了授权操作,企业微信将会把用户重定向回指定的 URI,并附带有一个名为 `code` 的查询字符串参数。接下来的任务就是在服务端接收这个 code 参数,并利用它去换取访问令牌 (access token),进而获取用户的 OpenID 或 UnionID 等基本信息以便于识别该用户身份。 以下是简化版的服务端处理逻辑伪代码示例: ```python import requests def exchange_code_for_token(code, app_id, secret_key): url = f"https://qyapi.weixin.qq.com/cgi-bin/gettoken?corpid={app_id}&corpsecret={secret_key}" response = requests.get(url) if response.status_code == 200 and 'errcode' not in response.json(): access_token = response.json().get('access_token') user_info_url = "https://qyapi.weixin.qq.com/cgi-bin/user/getuserinfo" params = { "access_token": access_token, "code": code } userinfo_response = requests.post(user_info_url, json=params) return userinfo_response.json() else: raise Exception("Failed to get access token") # 假设已经从客户端收到 code 参数 received_code = request.args.get('code') try: result = exchange_code_for_token(received_code, YOUR_CORP_ID, YOUR_SECRET_KEY) except Exception as e: print(e) else: openid = result['UserId'] # 使用 openid 完成本地系统的认证逻辑... ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值