前言
为了识别用户,每个用户针对每个公众号或小程序等应用会产生一个安全的OpenID,公众号或应用可将此ID进行存储,便于用户下次登录时辨识其身份,或将其与用户在第三方应用中的原有账号进行绑定。
用户授权登录小程序时会产生一个临时码code,通过接口传入code查出用户的openid。
有后端直接调用该接口获取openid并保存到数据库中
RestTemplateConfig
@Configuration
public class RestTemplateConfig {
@Autowired
RestTemplateConfig restTemplateConfig;
@Bean
public RestTemplate restTemplate(ClientHttpRequestFactory factory) {
return new RestTemplate(factory);
}
@Bean
public ClientHttpRequestFactory simpleClientHttpRequestFactory() {
SimpleClientHttpRequestFactory factory = new SimpleClientHttpRequestFactory();
factory.setReadTimeout(5000);
factory.setConnectTimeout(5000);
return factory;
}
}
controller
@RestController
@RequestMapping("/test01")
public class SendUrlController {
@Autowired
RestTemplate restTemplate;
@RequestMapping(value = "/openid", method = RequestMethod.POST)
@ResponseBody
public String getOpenId(@RequestParam("code") String code) {
String forObject = restTemplate.getForObject("https://api.weixin.qq.com/sns/jscode2session?appid=wx0e8d547f860fcb67&secret=10081fc0d92c63671bf4cc89fa282fca&js_code=" + code + "&grant_type=authorization_code", String.class);
try {
// 将json转为map
Map map = JSON.parseObject(forObject, Map.class);
// 当code已经使用过,则不能查出openid
String openid = "code错误";
if (map.containsKey("openid")) {
openid = map.get("openid").toString();
}
return openid;
} catch (Exception e) {
e.printStackTrace();
return e.getMessage();
}
}
}