class Weapps::CodeSessionsController < Weapps::BaseController def create return render_error('code不能为空') if params[:code].blank? reset_session logged = false result = Wechat::Weapp.jscode2session(params[:code]) Rails.logger.info("###########result: #{result}") Rails.logger.info("###########result: #{result['session_key']}") Rails.logger.info("###########result: #{result['unionid']}") # 能根据 code 拿到 unionid open_user = OpenUsers::Wechat.find_by(uid: result['unionid']) if open_user.present? && open_user.user successful_authentication(open_user.user) set_session_unionid(result['unionid']) logged = true else # 根据 code没拿到 unionid Rails.logger.info("[Weapp] session_key: #{result['session_key']}") Rails.logger.info("[Weapp] code: #{params[:code]}") user_info = Wechat::Weapp.decrypt(result['session_key'], params[:encrypted_data], params[:iv]) # 老用户,已绑定 open_user = OpenUsers::Wechat.find_by(uid: user_info['unionId']) if open_user.present? && open_user.user successful_authentication(open_user.user) logged = true end set_session_unionid(user_info['unionId']) user_info['nickname'] = user_info['nickName'] session[:wechat_user_extra] = user_info end set_session_openid(result['openid']) set_weapp_session_key(result['session_key']) # weapp session_key写入缓存 后续解密需要 render_ok(openid: result['openid'], logged: logged) unless logged rescue Wechat::Error => ex render_error(ex.message) end end