原创作品,允许转载,转载时请务必以超链接形式标明文章 、作者信息和本声明。否则将追究法律责任。

本案是为客户的合作单位开发的无线网络的网页认证系统。

本系统实现基于Web的Windows Active Directory用户验证(域用户验证)与数据库用户验证,调用Wiwiz Auth API实现Web认证。
无线网络为客户现有环境,每层一个无线路由器接到交换机,以前用WPA,现改为Web网页认证方式。
网络结构经小幅改动,Web认证网关采用Wiwiz虚拟机。
认证页面程序使用PHP + MySQL,调用Wiwiz Auth API接口。
该公司有数百员工,网络使用方面规定较严格。多数员工只能上内网,少部分员工有使用外网的权限(客户OA系统中登记备案)。
MySQL数据库为客户的OA系统数据库。
有外网使用权限的员工可以使用公司的Windows域账户或者OA系统的账户登录并认证。
重要客户来访时接待人员还可以通过程序后台申请授权码。
认证页效果请参考下图(已隐去客户LOGO与名称):

 

 

以下附源码:

index.php

 

 
  1. <?php 
  2. //**************************************************** 
  3. // Gets incoming parameters 
  4. //**************************************************** 
  5.   
  6. $pTokencode = $_REQUEST["tokencode"];   // incoming parameter "tokencode" 
  7. $pSrvurl = $_REQUEST["srvurl"];     // incoming parameter "srvurl" 
  8.   
  9. session_start(); 
  10. if($pTokencode != null)  
  11.     $_SESSION['tokencode'] = $pTokencode
  12. if($pSrvurl != null) 
  13.     $_SESSION['srvurl'] = $pSrvurl
  14. ?> 
  15.   
  16. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"
  17. <html> 
  18. <head> 
  19. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"
  20. <meta http-equiv="Content-Language" content="zh"
  21. <meta http-equiv="Pragma" content="no-cache"
  22. <meta http-equiv="Cache-Control" content="no-cache"
  23.  
  24. <title>Wifi Portal</title> 
  25. <script> 
  26. function onLogin1() { 
  27.      
  28.     if(document.getElementById("AuthType0").checked == false && document.getElementById("AuthType1").checked == false) { 
  29.         alert("请选择“使用OA系统账户登录”或“使用域账号登录”。"); 
  30.         return false;        
  31.     } 
  32.          
  33.     if(document.getElementById("agree1").checked == false) { 
  34.         alert("认证前您需要阅读并认同公司《计算机及网络使用管理规定》。"); 
  35.         return false; 
  36.     } 
  37.      
  38.     return true; 
  39.  
  40. function onLogin2() { 
  41.     if(document.getElementById("agree2").checked == false) { 
  42.         alert("认证前您需要阅读并认同《访客使用网络协议》。"); 
  43.         return false; 
  44.     } 
  45.      
  46.     return true; 
  47. </script> 
  48.  
  49. </head> 
  50.  
  51. <body> 
  52. <form action="auth.php" method="post"
  53.  
  54. <center> 
  55. <br> 
  56. <font style="font-size:22px" color="red"
  57. <b>XXX公司WiFi认证系统</font> 
  58. <br><br> 
  59.  
  60. <font style="font-size:14px"
  61. 本公司、子公司及合作单位员工请使用OA系统账户或域账户进行认证 
  62. <br> 
  63. (仅限开通使用Internet权限的员工) 
  64. <br><br> 
  65. 访客请使用授权码进行认证 
  66. </font></b> 
  67.  
  68. <br> 
  69. <br> 
  70.  
  71. <table width="760"
  72. <tr> 
  73. <td width="60%"
  74.  
  75. <table width="90%" height="340" border="0" cellspacing="1" cellpadding="5" bgcolor="#cccccc" style="font-size: 12px"
  76. <tr bgcolor="#eef1ff"
  77. <td align=center> 
  78.  
  79. <b><font style="font-size:14px">员工通道</b></font> 
  80.  
  81.  
  82. <table style="font-size:12px"
  83. <tr> 
  84. <td colspan=2> 
  85.  
  86. <br> 
  87. <input type="radio" name="AuthType" id="AuthType0" value="0" /> <label for="AuthType0">使用OA系统账户登录</label> 
  88. </td> 
  89. </tr> 
  90.  
  91. <tr> 
  92. <td> 
  93. 工号: 
  94. </td> 
  95. <td> 
  96. <input type="text" name="StaffId" /> 
  97. </td> 
  98. </tr> 
  99.  
  100. <tr> 
  101. <td> 
  102. 密码: 
  103. </td> 
  104. <td> 
  105. <input type="password" name="Pswd" /> 
  106. </td> 
  107. </tr> 
  108.  
  109. <tr> 
  110. <td colspan=2> 
  111. <input type="radio" name="AuthType" id="AuthType1" value="1" /> <label for="AuthType1">使用域账号登录</label> 
  112. </td> 
  113. </tr> 
  114.  
  115. <tr> 
  116. <td> 
  117. 所在域: 
  118. </td> 
  119. <td> 
  120. <select name="Domain"
  121. <option value="MD">MD</option> 
  122. <option value="Marketing">Marketing</option> 
  123. </select> 
  124. </td> 
  125. </tr> 
  126.  
  127. <tr> 
  128. <td> 
  129. 域账户名: 
  130. </td> 
  131. <td> 
  132. <input type="text" name="DomainUser" /> 
  133. </td> 
  134. </tr> 
  135.  
  136. <tr> 
  137. <td> 
  138. 密码: 
  139. </td> 
  140. <td> 
  141. <input type="password" name="DomainPswd" /> 
  142. </td> 
  143. </tr> 
  144.  
  145. </table> 
  146.  
  147. <br> 
  148. <input type="checkbox" name="agree1" id="agree1"><label for="agree1">我已阅读公司《<a href="http://172.23.1.16/hr/docs/k/12_doc.htm">计算机及网络使用管理规定</a>》</label> 
  149. <br><br> 
  150. <input type="submit" value="  登录 / 认证  " name="login1" οnclick="return onLogin1();" /> 
  151.  
  152. </td> 
  153. </tr> 
  154. </table> 
  155.  
  156. </td> 
  157.  
  158. <td width="40%"
  159.  
  160. <table width="90%" height="340" border="0" cellspacing="1" cellpadding="8" bgcolor="#cccccc" style="font-size: 12px"
  161. <tr bgcolor="#eef1ff"
  162. <td> 
  163. <center> 
  164. <b><font style="font-size:14px">访客通道</b></font> 
  165. <br><br> 
  166.  
  167. <table style="font-size:12px"
  168. <tr> 
  169. <td colspan=2> 
  170.  
  171. <center> 访客请使用授权码进行认证 <br><br> 
  172. </td> 
  173. </tr> 
  174.  
  175. <tr> 
  176. <td> 
  177.  
  178. 授权码: 
  179. </td> 
  180. <td> 
  181. <input type="text" style="width:100px" name="AuthCode" /> 
  182.  
  183. </td> 
  184. </tr> 
  185.  
  186.  
  187. </td> 
  188. </tr> 
  189. </table> 
  190.  
  191. <br> 
  192. <input type="checkbox" name="agree2" id="agree2"><label for="agree2">我已阅读并认同《<a href="http://172.23.1.16/hr/docs/k/11_doc.htm">访客使用网络协议</a>》</label> 
  193. <br><br> 
  194. <input type="submit" value="  认证  " name="login2" οnclick="return onLogin2();" /> 
  195.  
  196. <br> 
  197. <br> 
  198. </center> 
  199. *注: 如您正在访问本公司并需要使用本公司WiFi网络,请联系您的接待人员或客户经理以索取授权码 
  200. </td> 
  201. </tr> 
  202. </table> 
  203.  
  204. </td></tr></table> 
  205.  
  206. <br> 
  207. <font size=-1>帮助热线:内线5220    
  208.  
  209. </center> 
  210. </form> 
  211. </body> 
  212. </html> 

auth.php

 

 
  1. <?php 
  2. session_start(); 
  3.  
  4. $AD_HOST = "XXXXXX:389";    // Active Directory服务器 
  5.      
  6. $userkey = "XXXXXX";    // Wiwiz User Key 
  7.  
  8. $loginSuccess = false; 
  9.  
  10. if(isset($_POST['login1'])) { 
  11.     if($_POST['AuthType'] == '0' ) {            //员工通道 - 使用OA系统账户登录并认证 
  12.         $StaffId = $_POST['StaffId']; 
  13.         $Pswd = $_POST['Pswd']; 
  14.          
  15.         if($StaffId == ''
  16.             die("请输入工号!" ); 
  17.         if($Pswd == ''
  18.             die("请输入密码!" ); 
  19.          
  20.         $db = mysql_connect("localhost""root"or die("OA系统连接异常!"); 
  21.         //$db = mysql_connect(":/tmp/mysql.sock", "root") or die("OA系统连接异常!");       
  22.          
  23.         mysql_select_db("oadb",$db); 
  24.         $result = mysql_query("SELECT count(staffid) as cnt FROM usermaster where staffid='". mysql_real_escape_string($StaffId) ."' and pswd='". mysql_real_escape_string($Pswd) ."'"$db); 
  25.          
  26.         $cnt = mysql_result($result, 0, "cnt"); 
  27.          
  28.         mysql_close($db); 
  29.          
  30.         if($cnt <> '0'
  31.             $loginSuccess = true; 
  32.          
  33.     } else if($_POST['AuthType'] == '1' ) { //员工通道 - 使用域账户登录并认证 
  34.         $DomainUser = $_POST['DomainUser']; 
  35.         $DomainPswd = $_POST['DomainPswd']; 
  36.         $Domain = $_POST['Domain']; 
  37.  
  38.         if($DomainUser == ''
  39.             die("请输入域账户名!" ); 
  40.         if($DomainPswd == ''
  41.             die("请输入域账户密码!" ); 
  42.         if($Domain == ''
  43.             die("请选择所在域!" ); 
  44.          
  45.         $conn = ldap_connect($AD_HOSTor die("连接失败!" ); 
  46.  
  47.         if($conn){ 
  48.             // 
  49.             ldap_set_option ( $conn, LDAP_OPT_PROTOCOL_VERSION, 3 ); 
  50.             ldap_set_option ( $conn, LDAP_OPT_REFERRALS, 0 ); // Binding to ldap server 
  51.             $bd = ldap_bind($conn$DomainUser.'@'.$Domain$DomainPswd); //  or die ("域账户或密码错误。"); 
  52.             if($bd
  53.                 $loginSuccess = true; 
  54.         } else
  55.             echo "连接失败!"
  56.         } 
  57.     } 
  58.  
  59. if(isset($_POST['login2'])) {               //访客通道(使用授权码认证) 
  60.     $AuthCode = $_POST['AuthCode']; 
  61.      
  62.     if($AuthCode == ''
  63.         die("请输授权码!" ); 
  64.      
  65.     $db = mysql_connect("localhost""root"or die("OA系统连接异常!"); 
  66.      
  67.     mysql_select_db("oadb",$db); 
  68.     $result = mysql_query("SELECT count(id) as cnt FROM authcode where code='". mysql_real_escape_string($AuthCode). "'"$db); 
  69.      
  70.     $cnt = mysql_result($result, 0, "cnt"); 
  71.      
  72.     mysql_close($db); 
  73.      
  74.     if($cnt <> '0'
  75.         $loginSuccess = true; 
  76.   
  77.  
  78. // 
  79. // Do something you need. 
  80. // e.g. verify the user 
  81. //      ...... 
  82. // 
  83.  
  84. if($loginSuccess == false) { 
  85.  
  86.     echo "认证失败!";   // if user login failed, show an error message 
  87.  
  88. else { 
  89.  
  90.     //**************************************************** 
  91.     // Step 2. Do the pre-auth by calling Wiwiz Auth API 
  92.     // IMPORTANT: Do this on your server side(ASP, C#, JSP/Servlet, PHP...),  
  93.     //            but DO NOT do this on your client side (HTML/Javascript) 
  94.     //**************************************************** 
  95.  
  96.     // parameter "action" : REQUIRED! 
  97.     // set it to "1" to authenticate the user 
  98.     // set it to "0" to block the user 
  99.     $action = "1"
  100.  
  101.     // parameter "tokencode": REQUIRED! 
  102.     // set identical to the incoming parameter 
  103.     $tokencode = $_SESSION['tokencode']; 
  104.  
  105.     // parameter "srvurl": REQUIRED! 
  106.     // set identical to the incoming parameter   
  107.     $srvurl = $_SESSION['srvurl']; 
  108.  
  109.     // parameter "endtime" : OPTIONAL 
  110.     // Format: yyyy-mm-dd hh:MM:ss  e.g. 2012-05-31 21:39:00 
  111.     // set this parameter to set the time to close the user's Internet connection  
  112.     // Note: the value must be url-encoded.   
  113. //  $endtime = urlencode('2012-05-31 21:39:00'); 
  114.     $endtime = '';   
  115.  
  116.     // parameter "postauth" : OPTIONAL 
  117.     // E.g. http://www.YourDomain.com 
  118.     // set this parameter to redirect to a specified URL after authenticated. 
  119.     // Note: the value should be url-encoded.   
  120.     //$postauth = urlencode("http://www.wiwiz.com"); 
  121.     $postauth = '';  
  122.  
  123.     $parameters = "?wiwiz_auth_api=1&ver=1.0"// parameter "wiwiz_auth_api" and "ver". Fixed value 
  124.             "&tokencode="$tokencode . // parameter "tokencode". See above 
  125.             "&userkey="$userkey .     // parameter "userkey". Set your own User Key 
  126.             "&action="$action .       // parameter "action". See above 
  127.             "&endtime="$endtime .     // parameter "endtime". See above 
  128.             "&postauth="$postauth;    // parameter "postauth". See above 
  129.  
  130.     $verifycode = file_get_contents($srvurl . $parameters); 
  131.  
  132.     if (strpos ($verifycode"ERR") === 0) { 
  133.         // if there is an error, show error code 
  134.         echo "Error: "$verifycode
  135.  
  136.     } else { 
  137.         // OK, now. do Step 3. 
  138.  
  139.         //**************************************************** 
  140.         // Step 3. Complete the Authentication by calling Wiwiz Auth API 
  141.         //****************************************************   
  142.         $redirectUrl = $srvurl.     // use the value of incoming parameter "srvurl" as the redirection address 
  143.                 "?wiwiz_auth_api_login=1".  // parameter "wiwiz_auth_api_login" 
  144.                 "&tokencode="$tokencode . // parameter "tokencode", set identical to the incoming parameter    
  145.                 "&verifycode="$verifycode;    // parameter "verifycode", set identical to the incoming parameter   
  146.         ob_start(); 
  147.         header("Location: "$redirectUrl); // finally, do the redirection 
  148.         ob_flush(); 
  149.  
  150. //          echo "<script>location.href=\"". $redirectUrl ."\"</script>"; 
  151.  
  152.     } 
  153.  
  154.  
  155. ?> 

 

本文出自 “” 博客,请务必保留此出处