asp.net微信开发(用户分组管理)
程序员文章站
2023-12-21 12:19:46
上一篇已讲解到新建用户分组,移动用户到分组的功能,这一章主要讲解修改分组名称和删除分组
直接上代码,废话不多说,获取分组列表需要用到的实体类
///...
上一篇已讲解到新建用户分组,移动用户到分组的功能,这一章主要讲解修改分组名称和删除分组
直接上代码,废话不多说,获取分组列表需要用到的实体类
/// <summary> /// 微信分组类 /// </summary> public class wxgroupsinfo { public string group_id { get; set; }//分组编号 public string group_name { get; set; }//分组名称 public string group_count { get; set; }//分组人数 }
前台代码:
<!doctype html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title></title> <link href="css/style.css" rel="stylesheet" type="text/css" /> <style type="text/css"> .inputstyle { height:35px; line-height:35px; text-indent:5px; width:350px;background-image:url('images/inputbg.gif'); background-repeat:repeat-x;border-top:solid 1px #a7b5bc; border-left:solid 1px #a7b5bc; border-right:solid 1px #ced9df; border-bottom:solid 1px #ced9df;margin:15px auto 15px auto; } a:hover { cursor:pointer; } .g_title { width:100%; border-bottom:2px solid #ced9df;font-size:20px; font-weight:bold; text-align:left; text-indent:5px; height:40px; line-height:40px; } th { height:35px;background-image:url('images/th.gif'); background-repeat:repeat-x; } tr { height:30px; } #shownewgroup { width:300px; height:200px; background-color:white;z-index:9999; border:2px solid #ddd; top:40%; left:40%; background-color:#fff; position:fixed;margin:-100px auto auto -100px; display:none; } #shownewgroupzhezhaoceng { height:200%; width:200%; left:0px; top:0px;position:fixed; z-index:9998; background:rgb(50,50,50);background:rgba(0,0,0,0.5); display:none; } .closelogin { height:30px; border-bottom:2px solid #31bb34; text-align:right; line-height:30px; font-size:14px; font-weight:bold; } a:hover { cursor:pointer; } .inputstyle22 { height:35px; line-height:35px; text-indent:5px; width:280px;background-image:url('images/inputbg.gif'); background-repeat:repeat-x;border-top:solid 1px #a7b5bc; border-left:solid 1px #a7b5bc; border-right:solid 1px #ced9df; border-bottom:solid 1px #ced9df; float:left; margin:auto 5px auto 5px; } </style> <script src="../js/jquery-1.7.1.min.js" type="text/javascript"></script> <script type="text/javascript"> //修改分组名称调用的函数 function editroster(payno,name) { //alert(payno+":"+name); var url = '****.aspx?id=' + payno+"&name="+name;//转向网页的地址; var name = 'add'; //网页名称,可为空; var iwidth = 600; //弹出窗口的宽度; var iheight = 300; //弹出窗口的高度; //获得窗口的垂直位置 var itop = (window.screen.availheight - 30 - iheight) / 2; //获得窗口的水平位置 var ileft = (window.screen.availwidth - 10 - iwidth) / 2; window.open(url, name, 'height=' + iheight + ',innerheight=' + iheight + ',width=' + iwidth + ',innerwidth=' + iwidth + ',top=' + itop + ',left=' + ileft + ',status=no,toolbar=no,menubar=no,location=no,resizable=no,scrollbars=0,titlebar=no'); } $(document).ready(function () { $(".newgroups").click(function () { $("#shownewgroupzhezhaoceng").show(); $("#shownewgroup").show(); }), $('.closeloginpage').click(function () { $("#shownewgroupzhezhaoceng").hide(); $("#shownewgroup").hide(); }) }) </script> </head> <body> <form id="form1" runat="server"> <div class="place"> <span>位置:</span> <ul class="placeul"> <li><a href="welcome.aspx" target="rightframe">首页</a></li> <li>微信管理</li> <li>德桥员工服务中心----分组管理</li> </ul> </div> <div class="g_title">分组管理</div> <div id="shownewgroup"> <div class="closelogin"><a class="closeloginpage"><span style="float:left; color:#08a5e0; font-size:18px; text-indent:5px;">新建分组</span>关闭</a> </div> <div style="font-size:12px; height:40px; color:red; line-height:40px;"> 30字符以内</div> <input type="text" id="txtgroupsname" name="txtgroupsname" class="inputstyle22" maxlength="30" runat="server" value="分组名称" onfocus="if(value==defaultvalue){value='';this.style.color='#000'}" onblur="if(!value){value=defaultvalue;this.style.color='#999'}" style="color:#999"/> <asp:linkbutton id="linkbtncreategroup" runat="server" onclick="linkbtncreategroup_click"><div style="background-image:url('images/buttonbg.png'); width:111px; height:35px; line-height:35px; font-weight:bold;float:left; margin-top:20px; margin-left:5px; text-align:center;color:#fff;"> 确定创建</div></asp:linkbutton> </div> <div id="shownewgroupzhezhaoceng"></div> <table style="width:1124px; margin:10px auto 10px auto; border:1px solid #ecd9df;text-align:center;"> <asp:repeater id="repeatergrouplist" runat="server" onitemcommand="repeatergrouplist_itemcommand" onitemdatabound="repeatergrouplist_itemdatabound"> <headertemplate> <tr> <th>序号</th> <th>id编号</th> <th>分组名称</th> <th>分组人数</th> <th>操作</th> </tr> </headertemplate> <itemtemplate> <tr style='background-color: <%#(container.itemindex%2==0)?"#fff":"#ced9ff"%>'> <td><asp:label id="lbxuhao" runat="server" text=""></asp:label></td> <td><%# eval("group_id") %></td> <td><%# eval("group_name") %></td> <td><%# eval("group_count") %></td> <td> <a onclick="editroster('<%# eval("group_id") %>','<%# eval("group_name") %>');">修改分组名称</a> <asp:linkbutton id="linkbtndeletegroup" runat="server" commandname="deletegroups" commandargument='<%# eval("group_id") %>' >删除分组</asp:linkbutton> </td> </tr> </itemtemplate> </asp:repeater> </table> <a class="newgroups"><div style="background-image:url('images/buttonbg.png'); width:111px; height:35px; line-height:35px; margin:10px auto 10px 28px; font-weight:bold;float:left; text-align:center;color:#fff;"> ┼ 新建分组</div></a> </form> </body> </html>
后台代码如下:
protected void page_load(object sender, eventargs e) { if(!page.ispostback) { bindgrouplist(); this.databind(); } } private void bindgrouplist() { weixinserver wxs = new weixinserver(); ///从缓存读取accesstoken string access_token = cache["access_token"] as string; if (access_token == null) { //如果为空,重新获取 access_token = wxs.getaccesstoken(); //设置缓存的数据7000秒后过期 cache.insert("access_token", access_token, null, datetime.now.addseconds(7000), system.web.caching.cache.noslidingexpiration); } string access_tokento = access_token.substring(17, access_token.length - 37); string jsonres = ""; string content = cache["allgroups_content"] as string; if (content == null) { jsonres = "https://api.weixin.qq.com/cgi-bin/groups/get?access_token=" + access_tokento; httpwebrequest myrequest = (httpwebrequest)webrequest.create(jsonres); myrequest.method = "get"; httpwebresponse myresponse = (httpwebresponse)myrequest.getresponse(); streamreader reader = new streamreader(myresponse.getresponsestream(), encoding.utf8); content = reader.readtoend(); reader.close(); //设置缓存的数据7000秒后过期 cache.insert("allgroups_content", content, null, datetime.now.addseconds(7000), system.web.caching.cache.noslidingexpiration); } //使用前需要引用newtonsoft.json.dll文件 jobject jsonobj = jobject.parse(content); int groupsnum = jsonobj["groups"].count(); list<wxgroupsinfo> wxgrouplist = new list<wxgroupsinfo>(); for (int i = 0; i < groupsnum; i++) { wxgroupsinfo wginfo = new wxgroupsinfo(); wginfo.group_id = jsonobj["groups"][i]["id"].tostring(); wginfo.group_name = jsonobj["groups"][i]["name"].tostring(); wginfo.group_count = jsonobj["groups"][i]["count"].tostring(); wxgrouplist.add(wginfo); } this.repeatergrouplist.datasource = wxgrouplist; this.repeatergrouplist.databind(); } /// <summary> /// 绑定事件 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void repeatergrouplist_itemdatabound(object sender, repeateritemeventargs e) { if(e.item.itemtype==listitemtype.item||e.item.itemtype==listitemtype.alternatingitem) { label lbxuhao = e.item.findcontrol("lbxuhao") as label; int num = 1; lbxuhao.text = num.tostring(); for (int i = 0; i < this.repeatergrouplist.items.count;i++ ) { num += 1; lbxuhao.text = num.tostring(); } linkbutton linkbtndeletegroup = e.item.findcontrol("linkbtndeletegroup") as linkbutton; linkbtndeletegroup.attributes.add("onclick", "return confirm('您确定要删除该分组?删除后该分组内的人员即将恢复到默认分组!')"); } } /// <summary> /// 执行事件 /// </summary> /// <param name="source"></param> /// <param name="e"></param> protected void repeatergrouplist_itemcommand(object source, repeatercommandeventargs e) { //scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('删除接口已关闭!');location='wxgroupmanagelist.aspx';", true); if (e.commandname == "deletegroups") { weixinserver wxs = new weixinserver(); string res = ""; ///从缓存读取accesstoken string access_token = cache["access_token"] as string; if (access_token == null) { //如果为空,重新获取 access_token = wxs.getaccesstoken(); //设置缓存的数据7000秒后过期 cache.insert("access_token", access_token, null, datetime.now.addseconds(7000), system.web.caching.cache.noslidingexpiration); } string access_tokento = access_token.substring(17, access_token.length - 37); string posturl = "https://api.weixin.qq.com/cgi-bin/groups/delete?access_token=" + access_tokento; //post数据例子: post数据例子:{"group":{"id":108}} string groupid = e.commandargument.tostring(); string postdata = "{\"group\":{\"id\":\"" + groupid.tostring() + "\"}}"; res = wxs.getpage(posturl, postdata); scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('删除成功!由于缓存问题,您可能需要重新登录才能看到效果!');location='wxgroupmanagelist.aspx';", true); } } /// <summary> /// 创建分组 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void linkbtncreategroup_click(object sender, eventargs e) { if (this.txtgroupsname.value.tostring().equals("分组名称")) { //// scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('不能为空!')", true); this.txtgroupsname.focus(); return; } weixinserver wxs = new weixinserver(); string res = ""; ///从缓存读取accesstoken string access_token = cache["access_token"] as string; if (access_token == null) { //如果为空,重新获取 access_token = wxs.getaccesstoken(); //设置缓存的数据7000秒后过期 cache.insert("access_token", access_token, null, datetime.now.addseconds(7000), system.web.caching.cache.noslidingexpiration); } string access_tokento = access_token.substring(17, access_token.length - 37); string posturl = "https://api.weixin.qq.com/cgi-bin/groups/create?access_token=" + access_tokento; string postdata = "{\"group\":{\"name\":\"" + this.txtgroupsname.value.tostring().trim() + "\"}}"; res = wxs.getpage(posturl, postdata); scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('创建成功!如未显示,请退出重新登录即可!');location='wxgroupmanagelist.aspx';", true); }
修改分组名称的页面
前台代码:
<!doctype html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> <meta http-equiv="content-type" content="text/html; charset=utf-8"/> <title></title> <style type="text/css"> .inputstyle { height:35px; line-height:35px; text-indent:5px; width:280px;background-image:url('images/inputbg.gif'); background-repeat:repeat-x;border-top:solid 1px #a7b5bc; border-left:solid 1px #a7b5bc; border-right:solid 1px #ced9df; border-bottom:solid 1px #ced9df; float:left; margin:auto 5px auto 5px; } </style> </head> <body> <form id="form1" runat="server"> <table border="1" style=" width:500px; border-collapse:collapse; margin:20px auto 20px auto; line-height:40px;"> <tr> <td style="text-align:right;">分组编号:</td> <td> <asp:textbox id="txtgroupid" cssclass="inputstyle" enabled="false" runat="server"></asp:textbox></td> </tr> <tr> <td style="text-align:right;">分组名称:</td> <td> <asp:textbox id="txtgroupname" cssclass="inputstyle" runat="server"></asp:textbox> </td> </tr> <tr> <td></td> <td> <asp:linkbutton id="linkbtnset" runat="server" onclick="linkbtnset_click" ><div style="background-image:url('images/buttonbg.png'); width:111px; height:35px; line-height:35px; float:left; font-weight:bold;text-align:center;color:#fff;"> 设 置</div></asp:linkbutton></td> </tr> </table> </form> </body> </html>
后台代码:
protected void page_load(object sender, eventargs e) { if(!page.ispostback) { if (request.querystring["id"] != null) { string group_id = request.querystring["id"].tostring(); string group_name = request.querystring["name"].tostring(); this.txtgroupid.text = group_id.tostring(); this.txtgroupname.text = group_name.tostring(); this.txtgroupname.focus(); } } } /// <summary> /// 设置 /// </summary> /// <param name="sender"></param> /// <param name="e"></param> protected void linkbtnset_click(object sender, eventargs e) { if(string.isnullorwhitespace(this.txtgroupname.text.tostring().trim())) { scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('不能为空!');", true); this.txtgroupname.focus(); return; } if (this.txtgroupname.text.tostring().trim().length>30) { scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('组名称应在30个字符之内!');", true); this.txtgroupname.focus(); return; } weixinserver wxs = new weixinserver(); string res = ""; ///从缓存读取accesstoken string access_token = cache["access_token"] as string; if (access_token == null) { //如果为空,重新获取 access_token = wxs.getaccesstoken(); //设置缓存的数据7000秒后过期 cache.insert("access_token", access_token, null, datetime.now.addseconds(7000), system.web.caching.cache.noslidingexpiration); } string access_tokento = access_token.substring(17, access_token.length - 37); string posturl = "https://api.weixin.qq.com/cgi-bin/groups/update?access_token=" + access_tokento; //post数据例子:post数据例子:{"group":{"id":108,"name":"test2_modify2"}} //string postdata = "{\"group\":{\"name\":\"" + this.txtgroupsname.value.tostring().trim() + "\"}}"; string postdata = "{\"group\":{\"id\":\"" + txtgroupid.text.tostring() +"\",\"name\":\""+this.txtgroupname.text.tostring()+"\"}}"; res = wxs.getpage(posturl, postdata); //使用前需药引用newtonsoft.json.dll文件 jobject jsonobj = jobject.parse(res); ///获取返回结果的正确|true|false, string isright = jsonobj["errcode"].tostring();//0 string istrueorfalse = jsonobj["errmsg"].tostring();//ok if (isright.equals("0") && istrueorfalse.equals("ok")) { ///修改成功之后,刷新父窗体,关闭本页 scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('修改成功!如未正常显示,属缓存问题,请重新登录即可!');window.opener.location.reload();this.close();", true); } else { scriptmanager.registerclientscriptblock(this.page, this.gettype(), "", "alert('修改失败!');this.close();", true); } }
本文已被整理到了《asp.net微信开发教程汇总》,欢迎大家学习阅读。
以上就是用户分组管理的全部核心代码,仅供参考,希望对大家的学习有所帮助。