先获取微信用户头像和用户名,asp+ajax无刷新的1v1实时聊天手机页面,显示代码
时间: 2024-06-08 12:08:18 浏览: 150
获取微信用户头像和用户名需要使用微信开放平台提供的接口进行授权和获取用户信息,在这里我假设你已经完成了这些步骤。下面是一个简单的ASP+AJAX无刷新的1v1实时聊天手机页面的示例代码:
1. HTML页面代码:
```html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>1v1实时聊天</title>
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script>
<style type="text/css">
#chatBox{
width: 100%;
height: 500px;
overflow: auto;
border: 1px solid #ccc;
margin-bottom: 10px;
}
#inputBox{
width: 100%;
height: 50px;
margin-bottom: 10px;
}
#inputBox textarea{
width: 80%;
height: 100%;
float: left;
resize: none;
}
#inputBox button{
width: 18%;
height: 100%;
float: right;
background-color: #00bfff;
color: #fff;
border: none;
cursor: pointer;
}
</style>
</head>
<body>
<div id="chatBox"></div>
<div id="inputBox">
<textarea id="message" placeholder="请输入消息"></textarea>
<button id="sendBtn">发送</button>
</div>
<script type="text/javascript">
$(function(){
var ws;
var username = '<%=Session("username")%>'; //获取用户名
var avatarUrl = '<%=Session("avatarUrl")%>'; //获取头像URL
var chatBox = $('#chatBox');
var message = $('#message');
var sendBtn = $('#sendBtn');
var wsUrl = 'ws://localhost:8080'; //WebSocket服务器地址
//连接WebSocket服务器
function connect(){
ws = new WebSocket(wsUrl);
ws.onopen = function(){
console.log('WebSocket已连接');
//向服务器发送用户名和头像URL
ws.send(JSON.stringify({type:'login', username:username, avatarUrl:avatarUrl}));
};
ws.onmessage = function(event){
console.log(event);
var data = JSON.parse(event.data);
if(data.type == 'chat'){
//添加聊天记录到页面中
var chatItem = '<div><img src="'+data.avatarUrl+'">'+data.username+':'+data.message+'</div>';
chatBox.append(chatItem);
//滚动到最底部
chatBox.scrollTop(chatBox[0].scrollHeight);
}
};
ws.onclose = function(){
console.log('WebSocket已关闭');
};
ws.onerror = function(){
console.log('WebSocket连接错误');
};
}
//发送消息
function sendMessage(){
var msg = message.val();
if(msg == ''){
return;
}
ws.send(JSON.stringify({type:'chat', username:username, avatarUrl:avatarUrl, message:msg}));
message.val('');
}
//点击发送按钮发送消息
sendBtn.click(function(){
sendMessage();
});
//按Enter键发送消息
message.keydown(function(event){
if(event.keyCode == 13){
sendMessage();
}
});
//页面加载完成后连接WebSocket服务器
connect();
});
</script>
</body>
</html>
```
2. ASP代码:
```asp
<%@ Language=VBScript %>
<%
Dim username, avatarUrl
If Request.Cookies("userInfo") <> "" Then
'从cookie中获取用户名和头像URL
username = Server.URLEncode(Request.Cookies("userInfo")("username"))
avatarUrl = Server.URLEncode(Request.Cookies("userInfo")("avatarUrl"))
Else
'从微信开放平台获取access_token和用户信息
Dim appId, appSecret, code, accessToken, userInfoUrl, userInfoStr, userInfoJson, nickname, headimgurl
appId = "your_appId" '你的公众号appId
appSecret = "your_appSecret" '你的公众号appSecret
code = Request.QueryString("code") '微信授权回调页面的code参数
userInfoUrl = "https://api.weixin.qq.com/sns/oauth2/access_token?appid=" & appId & "&secret=" & appSecret & "&code=" & code & "&grant_type=authorization_code"
'发送HTTP请求获取access_token和openid
Set xmlHttp = Server.CreateObject("MSXML2.ServerXMLHTTP")
xmlHttp.Open "GET", userInfoUrl, False
xmlHttp.Send
accessToken = ""
openid = ""
If xmlHttp.Status = 200 Then
Set xml = Server.CreateObject("Microsoft.XMLDOM")
xml.async = False
xml.loadxml(xmlHttp.responseText)
accessToken = xml.getElementsByTagName("access_token")(0).Text
openid = xml.getElementsByTagName("openid")(0).Text
End If
userInfoUrl = "https://api.weixin.qq.com/sns/userinfo?access_token=" & accessToken & "&openid=" & openid & "&lang=zh_CN"
'发送HTTP请求获取用户信息
xmlHttp.Open "GET", userInfoUrl, False
xmlHttp.Send
If xmlHttp.Status = 200 Then
userInfoStr = xmlHttp.responseText
'解析用户信息JSON字符串
Set objJSON = Server.CreateObject("cJSON.SafeArray")
objJSON.Decode userInfoStr
nickname = Server.URLEncode(objJSON.Item("nickname"))
headimgurl = Server.URLEncode(objJSON.Item("headimgurl"))
'保存用户名和头像URL到cookie中
Response.Cookies("userInfo")("username") = nickname
Response.Cookies("userInfo")("avatarUrl") = headimgurl
username = nickname
avatarUrl = headimgurl
End If
Set xmlHttp = Nothing
End If
Session("username") = username '将用户名保存到Session中
Session("avatarUrl") = avatarUrl '将头像URL保存到Session中
%>
```
注意:以上示例代码仅供参考,实际使用时需要根据自己的需求进行修改和完善。
阅读全文