微信在国内目前无疑是最火的社交软件,智能手机装机必备。

微信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 +
"&timestamp=" + 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 微信分享功能的更多相关文章

  1. AndroidStudio用微信官方方法接入微信分享功能

    转载请注明出处:http://www.cnblogs.com/wangoublog/p/5367950.html 现在微信的功能众所周知,用户量.影响力也是惊人,很多应用接入微信的功能已成为一种不可缺 ...

  2. 微信分享功能引入页面-控制分享时候调用的标题、图片、url和微信按钮隐藏显示控制

    1.设置分享调用的标题.图片.url预览. 2.控制右上角三个点按钮的隐藏显示(和底部工具栏的显示隐藏--未测试). 3.判断网页是否在微信中被调用. <!doctype html> &l ...

  3. android APP 中微信分享功能实现 的总结

    //花了很长时间最终完成了微信分享功能,中间走了很多弯路,在此做一下小结,希望对在应用中使用到微信分享的朋友有所帮助. 主要问题就是下面两个: 1.为什么运行了项目之后,微信分享只是闪了一下就没有了? ...

  4. 微信开发】【Asp.net MVC】-- 微信分享功能

    [微信开发][Asp.net MVC]-- 微信分享功能 2017-01-15 09:09 by stoneniqiu, 12886 阅读, 15 评论, 收藏, 编辑 内嵌在微信中的网页,右上角都会 ...

  5. AndroidStudio怎么实现微信分享功能

    在应用中添加微信分享功能,需要在微信开放平台上传你的应用,审核通过后方可使用此功能. https://open.weixin.qq.com/网址 申请的过程比较简单,这里就不追溯了,贴一个友情链接 h ...

  6. Android微信分享功能实例+demo

    Android微信分享功能实例 1 微信开放平台注册 2 获得appId,添加到程序中,并运行程序 3 使用应用签名apk生成签名,添加到微信开放平台应用签名,完成注册 4 测试分享功能. 有问题请留 ...

  7. php框架tp3.2.3和js写的微信分享功能心得,分享的标题内容图片自定义

    https://blog.csdn.net/weixin_42231483/article/details/81585322 最近用PHP的tp3.2.3框架和js写的微信分享功能心得,分享的标题内容 ...

  8. VueJs单页应用实现微信网页授权及微信分享功能

    在实际开发中,无论是做PC端.WebApp端还是微信公众号等类型的项目的时候,或多或少都会涉及到微信相关的开发,最近公司项目要求实现微信网页授权,并获取微信用户基本信息的功能及微信分享的功能,现在总算 ...

  9. 【微信开发】【Asp.net MVC】-- 微信分享功能

    内嵌在微信中的网页,右上角都会有一个默认的分享功能.如下图所示,第一个为自定义的效果,第二个为默认的效果.实现了自定义的分享链接是不是更让人有点击的欲望?下面讲解下开发的过程. 一.准备,设置js接口 ...

  10. 在Unity3D项目中接入ShareSDK实现安卓平台微信分享功能(可使用ShareSDK默认UI或自定义UI)

    最近公司的大厅要重做,我协助主程一起制作新大厅和新框架,前面制作的编辑器也派上了用场.等全部功能做完后我会再写一个复盘,这两天主程在忙于写热更新的功能,所以把接入分享SDK功能的任务交给了我,Shar ...

随机推荐

  1. 【232】◀▶ IDL显示地理图像

    参考: 01   IMAGE 将图像数据以图形窗体的形式显示. 02   COLORBAR 在已经存在的IDL图形中增加一个colorbar或创建. 03   MAPGRID 在已经存在的IDL地图图 ...

  2. SQL Server 的数据库简单操作

    --创建数据库--create database 数据库名称[on [primary](name='主数据逻辑文件名',filename='完整的路径.文件名和拓展名'[,size=文件大小][,fi ...

  3. 如何在SqlServer中获取前端连接的IP地址,计算机名等信息

    在一些需求中,可能我们需要知道连接到SqlServer的前端程序的一些系统信息,比如前端连接的计算机名称,IP地址,什么时候开始请求连接,什么时候结束连接等信息. 如果你对SqlServer的系统函数 ...

  4. 文本换行word-wrap、word-break与white-space

    本文同步至微信公众号:http://mp.weixin.qq.com/s?__biz=MzAxMzgwNDU3Mg==&mid=401671055&idx=1&sn=b88c9 ...

  5. Erlang 从入门到精通(三) 改变工作目录

    对于初学者来书,经常会碰到下面的错误: no such file or directoryerror 提示找不到文件,这时候就需要将文件放到工作目录下,或者直接修改工作目录到文件所在位置. 右键ERl ...

  6. Java 字符串拼接 五种方法的性能比较分析 从执行100次到90万次

    [请尊重原创版权,如需引用,请注明来源及地址] > 字符串拼接一般使用“+”,但是“+”不能满足大批量数据的处理,Java中有以下五种方法处理字符串拼接,各有优缺点,程序开发应选择合适的方法实现 ...

  7. ViewPager的简单使用

    1.布局文件 a.主布局文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xml ...

  8. Activity启动模式

    ------siwuxie095 共4种启动模式:standard singleTop singleTask singleInstance 1.标准启动模式(standard) 也即默认的启动模式 ( ...

  9. jquery验证

    首先要引用js库 <script src="js/jquery-1.7.2.min.js"></script> jquery验证方式 function ch ...

  10. js自定义对象

    一,概述 在Java语言中,我们可以定义自己的类,并根据这些类创建对象来使用,在Javascript中,我们也可以定义自己的类,例如定义User类.Hashtable类等等. 目前在Javascrip ...