.net 微信分享功能
微信在国内目前无疑是最火的社交软件,智能手机装机必备。
微信api有java,php,Python语言的demo, 为毛没有C#的范例?兄长今天给各位带来一个。不叫哥(割)了,A股今天又暴跌【3912.77 -140.93 (-3.48%)】,为国满仓中...
1.微信帮助类:
public class WeChatHelper
{
/// <summary>
/// 公众号的全局唯一票据
/// </summary>
public static String ACCESS_TOKEN = null;
/// <summary>
/// 凭证有效时间7200秒
/// </summary>
public static DateTime? ACCESS_TOKEN_EXPIRE_TIME = null;
/// <summary>
/// 公众号用于调用微信JS接口的临时票据
/// </summary>
public static String JS_API_TICKET = null;
/// <summary>
/// 有效期为7200秒
/// </summary>
public static DateTime? JS_API_TICKET_EXPIRE_TIME = null; public const String APP_ID = "你的";
public const String APP_SECRET = "你的";
/// <summary>
/// 生成签名的随机串
/// </summary>
private String nonce = null;
/// <summary>
/// 生成签名的时间戳
/// </summary>
private String timestamp = null;
/// <summary>
/// 签名
/// </summary>
private String signature = null;
/// <summary>
/// 当前网页的URL,不包含#及其后面部分
/// </summary>
private String url = null; public WeChatHelper(string url)
{
this.url = url;
this.CheckAccessTokenAndJsApiTicket();
if (JS_API_TICKET == null || JS_API_TICKET.Trim().Length < )
{
throw new Exception("JS_API_TICKET is empty.");
}
this.Sign();
} private void CheckAccessTokenAndJsApiTicket()
{
DateTime now = DateTime.Now; if (ACCESS_TOKEN == null || ACCESS_TOKEN_EXPIRE_TIME == null || now > ACCESS_TOKEN_EXPIRE_TIME)
{
this.initAccessToken();
} if (JS_API_TICKET == null || JS_API_TICKET_EXPIRE_TIME == null || now > JS_API_TICKET_EXPIRE_TIME)
{
this.initJSAPITicket();
}
}
/// <summary>
/// 初始化凭证
/// </summary>
private void initAccessToken()
{
String result = "";
try {
DateTime expireTime = DateTime.Now; String accessURL = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + APP_ID + "&secret=" + APP_SECRET;
Uri realUrl = new Uri(accessURL);
WebRequest request = WebRequest.Create(realUrl);
HttpWebResponse response = (HttpWebResponse)request.GetResponse(); using (Stream resStream = response.GetResponseStream())
{
if (resStream != null)
{
StreamReader reader = new StreamReader(resStream, Encoding.Default);
result = reader.ReadToEnd();
}
if (resStream != null) resStream.Close();
} JavaScriptSerializer jss = new JavaScriptSerializer();
Dictionary<string, object> respDic = (Dictionary<string, object>)jss.DeserializeObject(result);
//var errCode = respDic["errcode"];
//var errMsg = respDic["errmsg"];
if (respDic.ContainsKey("errcode"))
{
throw new Exception("Fail to get weixin access token. ERROR Code:" + respDic["errcode"].ToString() + " errMsg:" + respDic["errmsg"].ToString());
}
//通过键access_token获取值
ACCESS_TOKEN = respDic["access_token"].ToString();
var expireIn = respDic["expires_in"];
if (expireIn != null){
expireTime = expireTime.AddSeconds(double.Parse(expireIn.ToString()));
} ACCESS_TOKEN_EXPIRE_TIME = expireTime; }finally{ }
}
/// <summary>
/// 初始临时票据
/// </summary>
private void initJSAPITicket()
{
String result = "";
try {
DateTime expireTime = DateTime.Now; String accessURL = "https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=" + ACCESS_TOKEN + "&type=jsapi"; Uri realUrl = new Uri(accessURL);
WebRequest request = WebRequest.Create(realUrl);
HttpWebResponse response = (HttpWebResponse)request.GetResponse(); using (Stream resStream = response.GetResponseStream())
{
if (resStream != null)
{
StreamReader reader = new StreamReader(resStream, Encoding.Default);
result = reader.ReadToEnd();
}
if (resStream != null) resStream.Close();
} JavaScriptSerializer jss = new JavaScriptSerializer();
Dictionary<string, object> respDic = (Dictionary<string, object>)jss.DeserializeObject(result); //var errCode = respDic["errcode"];
//var errMsg = respDic["errmsg"]; if (respDic.ContainsKey("errcode") && respDic["errcode"].ToString() != "")
{
throw new Exception("Fail to get weixin access token. ERROR Code:" + respDic["errcode"].ToString() + " errMsg:" + respDic["errmsg"].ToString());
} JS_API_TICKET = respDic["ticket"].ToString();
var expireIn = respDic["expires_in"]; if (expireIn != null){
expireTime = expireTime.AddSeconds(double.Parse(expireIn.ToString()));
} JS_API_TICKET_EXPIRE_TIME = expireTime; }finally{ }
} private void Sign()
{
this.nonce = Guid.NewGuid().ToString();
this.timestamp = ((long)((DateTime.UtcNow - new DateTime(, , , , , , DateTimeKind.Utc)).TotalMilliseconds/)).ToString(); String signatureUnCrpty = "jsapi_ticket=" + JS_API_TICKET +
"&noncestr=" + this.nonce +
"×tamp=" + this.timestamp +
"&url=" + this.url; this.signature = FormsAuthentication.HashPasswordForStoringInConfigFile(signatureUnCrpty, "SHA1");
} public String getNonce()
{
return nonce;
} public void setNonce(String nonce)
{
this.nonce = nonce;
} public String getTimestamp()
{
return timestamp;
} public void setTimestamp(String timestamp)
{
this.timestamp = timestamp;
} public String getSignature()
{
return signature;
} public void setSignature(String signature)
{
this.signature = signature;
} public String getUrl()
{
return url;
} public void setUrl(String url)
{
this.url = url;
}
}
2.前端脚本:wechat.js
需要引入 <script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js" type="text/javascript" ></script>
var titleStr = '测一测,你是哪个小升初名校的菜';
var descStr = '测一测,你是哪个小升初名校的菜';
var linkStr = window.location.href;
var logoStr = 'http://game.zy.com/Content/images/share_icon.png';
var optionTimeline = {
title: titleStr,
desc: descStr,
link: linkStr,
imgUrl: logoStr,
trigger: function (res) {
//alert('用户点击分享到朋友圈');
},
success: function (res) {
//alert('已分享');可以统计分享到朋友圈次数
$.ajax({
url: '/Game/SetShare',
type: 'POST',
async: false,
cache: false,
data: { typeID: 1 },
success: function (objJson) { }
});
}
};
var optionAppMessag ={
title: titleStr,
desc: descStr,
link: linkStr,
imgUrl: logoStr,
trigger: function (res) {
//alert('用户点击发送给朋友');
},
success: function (res) {
//alert('已分享');可以统计发送朋友次数
$.ajax({
url: '/Game/SetShare',
type: 'POST',
async: false,
cache: false,
data: { typeID: 2 },
success: function (objJson) { }
});
},
cancel: function (res) {
//alert('已取消');
},
fail: function (res) {
//alert(JSON.stringify(res));
}
};
function getWeChat() {
$.ajax({
url: '/Game/GetWeChatInfo',
type: 'GET',
async: false,
cache: false,
data: { 'url': linkStr },
success: function (objJson) {
// if (objJson.success) {
var objJson = eval('(' + objJson + ')'); //由JSON字符串转换为JSON对象
var appId = objJson.APP_ID;
var timestamp = objJson.TIMESTAMP;
var nonce = objJson.NONCE;
var signature = objJson.SIGNATURE;
wx.config({
debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: appId, // 必填,公众号的唯一标识
timestamp: timestamp, // 必填,生成签名的时间戳
nonceStr: nonce, // 必填,生成签名的随机串
signature: signature, // 必填,签名,见附录1
jsApiList: ['onMenuShareTimeline', 'onMenuShareAppMessage'] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2
});
// }
// else { // }
} }); }
//初始分享数据
function weChatShare(optionAppMessag, optionTimeline) {
wx.ready(function () {
wx.onMenuShareAppMessage(optionAppMessag);
wx.onMenuShareTimeline(optionTimeline);
})
};
wx.error(function(res){
//alert("Error weixin");
// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。 });
getWeChat();
weChatShare(optionAppMessag, optionTimeline);
以上代码封装了相关参数,原因是 weChatShare() 方法初始了分享的标题,如果要使用动态的标题,必须在获取动态数据后在初始化一次。
/* 游戏结束调用 返回答题的json */
window.gameOver = function (strJson) { $.ajax({
url: "/Game/SumbmitAnswer",
type: "POST",
data: { answer: strJson },
timeout: 5000,
async: false,
dataType: "json",
success: function (result) {
/* 更新视图 */
if (jc.hasUI("results")) {
jc.ui.results.all(function (i, obj) {
obj.setInfo({ scrollName: result.School, right: result.RightNum, ranking: result.Beat });
//初始化微信分享新数据
optionTimeline.title = optionAppMessag.title = "我答对了" + result.RightNum + "道题,打败了" + result.Beat + "%的学生,成为" + result.School + "学校的潜力学生. 放学后别走,等你来挑战";
weChatShare(optionAppMessag, optionTimeline);
});
}
}
}); }
.net 微信分享功能的更多相关文章
- AndroidStudio用微信官方方法接入微信分享功能
转载请注明出处:http://www.cnblogs.com/wangoublog/p/5367950.html 现在微信的功能众所周知,用户量.影响力也是惊人,很多应用接入微信的功能已成为一种不可缺 ...
- 微信分享功能引入页面-控制分享时候调用的标题、图片、url和微信按钮隐藏显示控制
1.设置分享调用的标题.图片.url预览. 2.控制右上角三个点按钮的隐藏显示(和底部工具栏的显示隐藏--未测试). 3.判断网页是否在微信中被调用. <!doctype html> &l ...
- android APP 中微信分享功能实现 的总结
//花了很长时间最终完成了微信分享功能,中间走了很多弯路,在此做一下小结,希望对在应用中使用到微信分享的朋友有所帮助. 主要问题就是下面两个: 1.为什么运行了项目之后,微信分享只是闪了一下就没有了? ...
- 微信开发】【Asp.net MVC】-- 微信分享功能
[微信开发][Asp.net MVC]-- 微信分享功能 2017-01-15 09:09 by stoneniqiu, 12886 阅读, 15 评论, 收藏, 编辑 内嵌在微信中的网页,右上角都会 ...
- AndroidStudio怎么实现微信分享功能
在应用中添加微信分享功能,需要在微信开放平台上传你的应用,审核通过后方可使用此功能. https://open.weixin.qq.com/网址 申请的过程比较简单,这里就不追溯了,贴一个友情链接 h ...
- Android微信分享功能实例+demo
Android微信分享功能实例 1 微信开放平台注册 2 获得appId,添加到程序中,并运行程序 3 使用应用签名apk生成签名,添加到微信开放平台应用签名,完成注册 4 测试分享功能. 有问题请留 ...
- php框架tp3.2.3和js写的微信分享功能心得,分享的标题内容图片自定义
https://blog.csdn.net/weixin_42231483/article/details/81585322 最近用PHP的tp3.2.3框架和js写的微信分享功能心得,分享的标题内容 ...
- VueJs单页应用实现微信网页授权及微信分享功能
在实际开发中,无论是做PC端.WebApp端还是微信公众号等类型的项目的时候,或多或少都会涉及到微信相关的开发,最近公司项目要求实现微信网页授权,并获取微信用户基本信息的功能及微信分享的功能,现在总算 ...
- 【微信开发】【Asp.net MVC】-- 微信分享功能
内嵌在微信中的网页,右上角都会有一个默认的分享功能.如下图所示,第一个为自定义的效果,第二个为默认的效果.实现了自定义的分享链接是不是更让人有点击的欲望?下面讲解下开发的过程. 一.准备,设置js接口 ...
- 在Unity3D项目中接入ShareSDK实现安卓平台微信分享功能(可使用ShareSDK默认UI或自定义UI)
最近公司的大厅要重做,我协助主程一起制作新大厅和新框架,前面制作的编辑器也派上了用场.等全部功能做完后我会再写一个复盘,这两天主程在忙于写热更新的功能,所以把接入分享SDK功能的任务交给了我,Shar ...
随机推荐
- 【232】◀▶ IDL显示地理图像
参考: 01 IMAGE 将图像数据以图形窗体的形式显示. 02 COLORBAR 在已经存在的IDL图形中增加一个colorbar或创建. 03 MAPGRID 在已经存在的IDL地图图 ...
- SQL Server 的数据库简单操作
--创建数据库--create database 数据库名称[on [primary](name='主数据逻辑文件名',filename='完整的路径.文件名和拓展名'[,size=文件大小][,fi ...
- 如何在SqlServer中获取前端连接的IP地址,计算机名等信息
在一些需求中,可能我们需要知道连接到SqlServer的前端程序的一些系统信息,比如前端连接的计算机名称,IP地址,什么时候开始请求连接,什么时候结束连接等信息. 如果你对SqlServer的系统函数 ...
- 文本换行word-wrap、word-break与white-space
本文同步至微信公众号:http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401671055&idx=1&sn=b88c9 ...
- Erlang 从入门到精通(三) 改变工作目录
对于初学者来书,经常会碰到下面的错误: no such file or directoryerror 提示找不到文件,这时候就需要将文件放到工作目录下,或者直接修改工作目录到文件所在位置. 右键ERl ...
- Java 字符串拼接 五种方法的性能比较分析 从执行100次到90万次
[请尊重原创版权,如需引用,请注明来源及地址] > 字符串拼接一般使用“+”,但是“+”不能满足大批量数据的处理,Java中有以下五种方法处理字符串拼接,各有优缺点,程序开发应选择合适的方法实现 ...
- ViewPager的简单使用
1.布局文件 a.主布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xml ...
- Activity启动模式
------siwuxie095 共4种启动模式:standard singleTop singleTask singleInstance 1.标准启动模式(standard) 也即默认的启动模式 ( ...
- jquery验证
首先要引用js库 <script src="js/jquery-1.7.2.min.js"></script> jquery验证方式 function ch ...
- js自定义对象
一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...