Discuz! 官方站

 找回密码
 立即注册

QQ登录

只需一步,快速开始

DNSPod全新套餐 限时免费领取
搜索
查看: 11607|回复: 21

[发布] 用Discuz/UCenter账号实现Wifi登录认证

[复制链接]
发表于 2012-8-5 00:04:34 | 显示全部楼层 |阅读模式
DNSPod全新套餐 限时免费领取
本帖最后由 tiida2011 于 2012-8-5 00:07 编辑

如果你有一个用Discuz/UCenter构建的网站,还有自己的Wifi基站或热点,那你可以用Wiwiz为你的Wifi热点做一个入口登录页面。当wifi终端用户连到你的热点时,打开任何网页都会先显示你的wifi登录页面,也就是web认证页面,然后输入他在你的网站的用户名和密码之后才能通过认证。并且认证之后,浏览器会跳转到网站首页。
效果如下图:


Web认证页面



认证后跳转至网站首页


实现方法如下:
用PHP写web登录页,调用Wiwiz Auth API(需要Wiwiz专业版)。
我的登录页的文件名是myauth.php,将其放置在服务器的discuz根目录上即可。
myauth.php代码如下:
  1. <?php
  2. /*
  3. * 用Discuz(UCenter)用户账号实现Wifi Portal认证(Web认证)
  4. * 调用Wiwiz Auth API
  5. * 作者:tiida_2011@163.com
  6. */

  7. $userkey = "XXXXXXXXXXXXXXXXXX";        //替换为你的Wiwiz User Key

  8. //****************************************************
  9. // Gets incoming parameters
  10. //****************************************************

  11. $pTokencode = $_REQUEST["tokencode"];        // incoming parameter "tokencode"
  12. $pSrvurl = $_REQUEST["srvurl"];                // incoming parameter "srvurl"

  13. session_start();
  14. if($pTokencode != null)
  15.         $_SESSION['tokencode'] = $pTokencode;
  16. if($pSrvurl != null)
  17.         $_SESSION['srvurl'] = $pSrvurl;
  18. ?>

  19. <html>
  20. <head>
  21. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  22. <meta http-equiv="Content-Language" content="zh">
  23. <meta http-equiv="Pragma" content="no-cache">
  24. <meta http-equiv="Cache-Control" content="no-cache">
  25. <title> Discuz无线网络认证 </title>
  26. </head>
  27. <body>

  28. <form method="post">
  29. <center>
  30. <b><h2>Discuz无线网络</h2>



  31. 请使用网站账号进行认证
  32. </b>
  33.          
  34. 用户名: <input type="text" name="username" />



  35. 密码: <input type="password" name="password" />



  36. <input type="submit" name="login" value="登录/认证" />


  37. </center>

  38. <?php
  39. if(isset($_REQUEST['login'])) {        // if "Login" button is clicked

  40.         //****************************************************
  41.         // Step 1. Do your business. E.g. check user login ...
  42.         //****************************************************
  43.         define('UC_CONNECT', 'mysql');        // 连接 UCenter 的方式: mysql/NULL, 默认为空时为 fscoketopen()
  44.                                                                         // mysql 是直接连接的数据库, 为了效率, 建议采用 mysql

  45.         //数据库相关 (mysql 连接时, 并且没有设置 UC_DBLINK 时, 需要配置以下变量)
  46.         define('UC_DBHOST', 'localhost');                                // UCenter 数据库主机
  47.         define('UC_DBUSER', 'root');                                        // UCenter 数据库用户名
  48.         define('UC_DBPW', '');                                                        // UCenter 数据库密码
  49.         define('UC_DBNAME', 'discuz');                                        // UCenter 数据库名称
  50.         define('UC_DBCHARSET', 'UTF-8');                                // UCenter 数据库字符集
  51.         define('UC_DBTABLEPRE', 'discuz.pre_ucenter_');        // UCenter 数据库表前缀

  52.         //通信相关
  53.         define('UC_KEY', '');                                // 与 UCenter 的通信密钥, 要与 UCenter 保持一致
  54.         define('UC_API', '');                                // UCenter 的 URL 地址, 在调用头像时依赖此常量
  55.         define('UC_CHARSET', 'gbk');                // UCenter 的字符集
  56.         define('UC_IP', '');                                // UCenter 的 IP, 当 UC_CONNECT 为非 mysql 方式时, 并且当前应用服务器解析域名有问题时, 请设置此值
  57.         define('UC_APPID', 1);                                // 当前应用的 ID
  58.         
  59.         require_once './uc_client/client.php';

  60.         if(isset($_POST['login'])) {
  61.                 list($uid, $username, $password, $email) = uc_user_login($_POST['username'], $_POST['password']);
  62.                 if($uid > 0) {
  63.                         $loginSuccess = true;
  64.                 } else {
  65.                         $loginSuccess = false;
  66.                 }
  67.         }

  68.         if($loginSuccess == false) {

  69.                 echo "用户名或密码错误!";        // if user login failed, show an error message

  70.         } else {

  71.                 //****************************************************
  72.                 // Step 2. Do the pre-auth by calling Wiwiz Auth API
  73.                 // IMPORTANT: Do this on your server side(ASP, C#, JSP/Servlet, PHP...),
  74.                 //            but DO NOT do this on your client side (HTML/Javascript)
  75.                 //****************************************************

  76.                 // parameter "action" : REQUIRED!
  77.                 // set it to "1" to authenticate the user
  78.                 // set it to "0" to block the user
  79.                 $action = "1";

  80.                 // parameter "tokencode": REQUIRED!
  81.                 // set identical to the incoming parameter
  82.                 $tokencode = $_SESSION['tokencode'];

  83.                 // parameter "srvurl": REQUIRED!
  84.                 // set identical to the incoming parameter        
  85.                 $srvurl = $_SESSION['srvurl'];

  86.                 // parameter "endtime" : OPTIONAL
  87.                 // Format: yyyy-mm-dd hh:MM:ss  e.g. 2012-05-31 21:39:00
  88.                 // set this parameter to set the time to close the user's Internet connection
  89.                 // Note: the value must be url-encoded.  
  90.                 $endtime = "";        //urlencode('2012-05-31 21:39:00');                //设置wifi使用期限

  91.                 // parameter "postauth" : OPTIONAL
  92.                 // E.g. http://www.YourDomain.com
  93.                 // set this parameter to redirect to a specified URL after authenticated.
  94.                 // Note: the value should be url-encoded.  
  95.                 $postauth = urlencode("http://192.168.1.250/home");                //wifi认证后跳转至网站首页

  96.                 $parameters = "?wiwiz_auth_api=1&ver=1.0". // parameter "wiwiz_auth_api" and "ver". Fixed value
  97.                                 "&tokencode=". $tokencode .        // parameter "tokencode". See above
  98.                                 "&userkey=". $userkey .                // parameter "userkey". Set your own User Key
  99.                                 "&action=". $action .                // parameter "action". See above
  100.                                 "&endtime=". $endtime .                // parameter "endtime". See above
  101.                                 "&postauth=". $postauth;         // parameter "postauth". See above

  102.                 $verifycode = file_get_contents($srvurl . $parameters);

  103.                 if (strpos ($verifycode, "ERR") === 0) {
  104.                         // if there is an error, show error code
  105.                         echo "Error: ". $verifycode;

  106.                 } else {
  107.                         // OK, now. do Step 3.

  108.                         //****************************************************
  109.                         // Step 3. Complete the Authentication by calling Wiwiz Auth API
  110.                         //****************************************************        
  111.                         $redirectUrl = $srvurl.                // use the value of incoming parameter "srvurl" as the redirection address
  112.                                         "?wiwiz_auth_api_login=1".        // parameter "wiwiz_auth_api_login"
  113.                                         "&tokencode=". $tokencode .        // parameter "tokencode", set identical to the incoming parameter        
  114.                                         "&verifycode=". $verifycode;        // parameter "verifycode", set identical to the incoming parameter        
  115.                         ob_start();
  116.                         header("Location: ". $redirectUrl);        // finally, do the redirection
  117.                         ob_flush();

  118. //                        echo "<script>location.href="". $redirectUrl .""</script>";

  119.                 }

  120.         }
  121. }
  122. ?>

  123. </form>

  124. </body>
  125. </html>
复制代码

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
 楼主| 发表于 2012-8-5 00:08:47 | 显示全部楼层
补充一下,如果不了解Wiwiz技术,可以到www.wiwiz.com/zh/faq看一下
回复

使用道具 举报

发表于 2012-8-5 00:29:30 | 显示全部楼层
bbs.52taian.com 我的可以么
回复

使用道具 举报

发表于 2012-8-5 00:45:23 | 显示全部楼层
留名  關注
回复

使用道具 举报

发表于 2012-8-5 00:52:34 | 显示全部楼层
表示关注一下
回复

使用道具 举报

发表于 2012-8-5 00:54:26 | 显示全部楼层
看着挺神奇,不知是什么东西
回复

使用道具 举报

发表于 2012-8-5 03:37:15 | 显示全部楼层
额 有何用处呢。。。。
http://www.567ca.com
回复

使用道具 举报

头像被屏蔽
发表于 2012-8-5 05:00:33 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
回复

使用道具 举报

发表于 2012-8-5 10:14:57 | 显示全部楼层
来看看 ,你也可以看看- www.ggbm.cn 贵港便民网
回复

使用道具 举报

发表于 2012-8-5 10:40:46 来自手机 | 显示全部楼层
如果可以用论坛积分换上网时间就更好咯!或者就是只能浏览指定的网站,,
来自:Discuz! 官方站 Android客户端
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Discuz! Q 3.0 全新来袭 助力变现

小黑屋|Discuz! 官方站 ( 粤B2-20090059-165 )star

GMT+8, 2021-11-28 07:42

Powered by Discuz! X3.4

Copyright © 2001-2019 Tencent Cloud.

快速回复 返回顶部 返回列表