You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
educoder/app/libs/wechat/weapp.rb

49 lines
1.3 KiB

5 years ago
class Wechat::Weapp
5 years ago
class << self
attr_accessor :appid, :secret
delegate :access_token, :jscode2session, to: :client
def client
@_client ||= Wechat::Client.new(appid, secret)
end
5 years ago
def session_key(openid)
Rails.cache.read(session_key_cache_key(openid))
end
def write_session_key(openid, session_key)
Rails.cache.write(session_key_cache_key(openid), session_key)
end
def verify?(openid, str, signature)
session_key = session_key(openid)
Digest::SHA1.hexdigest("#{str}#{session_key}") == signature
end
def decrypt(session_key, encrypted_data, iv)
5 years ago
session_key = Base64.decode64(session_key)
encrypted_data = Base64.decode64(encrypted_data)
5 years ago
iv = Base64.decode64(iv)
cipher = OpenSSL::Cipher::AES.new(128, :CBC)
cipher.decrypt
cipher.padding = 0
cipher.key = session_key
cipher.iv = iv
5 years ago
Rails.logger.info("[Weapp] encrypted_data: #{encrypted_data}")
5 years ago
data = cipher.update(encrypted_data) << cipher.final
5 years ago
Rails.logger.info("[Weapp] data: #{data}")
5 years ago
result = JSON.parse(data[0...-data.last.ord])
5 years ago
raise Wechat::Error.new(-1, '解密错误') if result.dig('watermark', 'appid') != appid
5 years ago
result
end
private
def session_key_cache_key(openid)
"weapp:#{appid}:#{openid}:session_key"
end
5 years ago
end
end