.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 ...
随机推荐
- ---bind 配置
http://blog.csdn.net/zjunjun/article/details/7419125
- SQL Server 数据库的维护(二)__触发器
--维护数据库-- --触发器-- --概述: 触发器是一种特殊类型的存储过程,用来强制执行业务规则.在调用执上,触发器不能像存储过程那样可以由用户通过T-SQL语句直接调用,而是需要有数据库所发生的 ...
- web初学之request,session与application
request (1)request的setAttribute()与getAttribute()方法一般都是成对出现,首先通过setAttribute()方法设置属性与属性值,然后通过getAttri ...
- 很不错的sql练习题(select)
创建表和输入数据 CREATE TABLE STUDENT (SNO VARCHAR(3) NOT NULL, SNAME VARCHAR(4) NOT NULL, SSEX VARC ...
- 关于c#静态构造函数
http://baike.baidu.com/view/2634573.htm?fr=aladdin 在百科上看到C#的新特性静态构造函数,其中提到静态构造函数“不能继承” 今天做了个试验,发现实际上 ...
- 谈谈Activiti中流程对象之间的关系
详细见:http://www.kafeitu.me/activiti/2012/03/22/workflow-activiti-action.html (咖啡兔好牛!) 详细见: http://blo ...
- redis——持久化篇
众所周知,redis是内存数据库,它把数据存储在内存中,这样在加快读取速度的同时也对数据安全性产生了新的问题,即当redis所在服务器发生宕机后,redis数据库里的所有数据将会全部丢失. 为了解决这 ...
- 初试Nodejs——使用keystonejs创建博客网站1(安装keystonejs)
我正在阿里云上创建一个简单的个人博客网站,刚好正在尝试NodeJs,决定找一款基于NodeJs的CMS来完成这个工作,最后找到了KeyStoneJS. KeyStoneJS是基于Express和Mon ...
- Java 标识符、数据类型、运算符
一.标识符 1.组成 首字母(字母,下划线,﹩)+其余部分(数字,字母,下划线,﹩) 2.命名规范 ①由大小写字母.下划线.数字.﹩ ②数字不能开头 ③标识符长度没有限制 ④标识符不能是关键字和保留字 ...
- Shell基础-ech0,cat,history,alias,unalias,bash快捷键,wc,执行结果写入文件
1 系统所支持的shell存放于 /etc/shells 文件中,shell脚本的开头 #!/bing/bash 是指定使用的脚本类型 不能省略,省略之后有些文件可以执行,但容易出错 这行不是注释 2 ...