.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 ...
随机推荐
- Redis_DataType
Redis_DataType.html :first-child{margin-top:0!important}img.plugin{box-shadow:0 1px 3px rgba(0,0,0,. ...
- windows程序里新窗体不在任务栏显示,无标题拖动,键盘事件,始终显示在主窗体上面,单实例运行等
不显示在任务栏,Alt+Tab也不显示 protected override CreateParams CreateParams { get { const int WS_EX_APPWINDOW = ...
- python的类与对象
类与对象 1.什么是类 类和函数一样是程序编程的一种方式,在处理某些问题的时候类比函数更加适合让编程变得简化,在python里面函数式编程和类编程都是为了简化代码的一种编程方式,具体应用那个则由具体问 ...
- android SurfaceView中播放视频 按视频的原始比例播放
OnPreparedListener mediaPlayerOnPreparedListener = new OnPreparedListener() { @Override public void ...
- Unable to load performance pack. Using Java I/O instead的解决办法?
启动的时候报下面的错误: <BEA-000438> <Unable to load performance pack. Using Java I/O instead. Please ...
- Devexpress WidgetView 使用总结
效果图: 1.添加DocumentManager控件 2.Convert to WidgetView 3.添加Document,设定ControlTypeName属性,第5步用到 4.添加StackG ...
- 使用Goertzel算法识别DTMF信号
Goertzel算法 Goertzel算法由Gerald Goertzel在1958年提出,用于数字信号处理,是属于离散傅里叶变换的范畴,目的是从给定的采样中求出某一特定频率信号的能量,用于有效性的评 ...
- 十二 .ocBlock
NSProxy是一个不继承NSObject的根类(尽管它遵守NSObject协议),调用[[NSProxy alloc]init]将会产生一个运行异常. 所幸,oc引入被称为“块代码”的第一级函数的概 ...
- eclipse项目自动发布到tomcat目录,缺文件。
eclipse项目自动发布到tomcat目录,缺文件. 解决方案: 项目--Properties-->Deployment Assembly-->Add--> Folder Add- ...
- grunt 基本使用使用(一)。
使用grunt 之前,需要做一些基本工作. 1.在E盘 新建空文件夹 grunt. 2.在grunt目录下新建package.json 文件,用了存储 npm模块的依赖项.基本依赖块代码如下: { & ...