d

Siren24 페이지 이동없이 Socket 으로 실명인증( UTF-8)

phpschool.com에서 퍼옴.
정말 대단합니다...^^

ssn.html//
##########################################
<html>
<body>

<script type="text/javascript">
var xmlhttp = XMLHTTP();

function XMLHTTP() {
try {
xmlhttp = new ActiveXObject("MSXML2.XMLHTTP");
}
catch(e) {
xmlhttp = new XMLHttpRequest();
}
return xmlhttp;
}
function remove_space( str ) {
str = str.replace(/\s+/g,"");
return str;
}
function is_numeric( str ) {
if ( str == str.match(/[0-9]+$/) )
{
return true;
}
else { return false; }
}
function is_ssn( ssn1 , ssn2 ) {
if ( !is_numeric(ssn1) || !is_numeric(ssn2) || ssn1.length != 6 || ssn2.length !=7 ) { return false; }
else { return true; }
}

function chk_ssn() {

var name = remove_space( document.getElementById("name").value );
var ssn1 = remove_space( document.getElementById("ssn1").value );
var ssn2 = remove_space( document.getElementById("ssn2").value );
if ( name == "" )
{
alert('이름을 입력해 주세요');
document.getElementById("name").focus();
return false;
}
else if( !is_ssn( ssn1 , ssn2 ))
{
alert('주민등록번호를 정확히 입력해 주시기 바랍니다.');
document.getElementById("ssn1").focus();
return false;
}
else {

document.getElementById("chk_ssn_msg").innerHTML="실명 확인중입니다.";
try
{
with( xmlhttp ) {
open("POST", "chk_ssn.php", true);
setRequestHeader("Content-Type", "application/x-www-form-urlencoded");

onreadystatechange = function() {

if (xmlhttp.readyState == 4) {
if ( xmlhttp.status==200)
{
var res = remove_space(xmlhttp.responseText) ;
var res_ = res.split("|");
res_no = res_[0];

if ( res_no == 99)
{
document.getElementById("chk_ssn_msg").innerHTML="<a onclick=\"chk_ssn();\">실명인증</a>";
alert('기존에 가입하신 아이디가 있습니다.');
}
else if ( res_no=="1" ) {
document.getElementById("chk_ssn_msg").innerHTML="<a onclick=\"chk_ssn();\">실명인증</a>";
alert('실명확인 성공.');
}
else if (res_no==2 || res_no == 4 )
{
document.getElementById("chk_ssn_msg").innerHTML="<a onclick=\"chk_ssn();\">실명인증</a>";
alert('주민등록번호 오류 입니다. 다시 입력해 주세요.');

}
else {

document.getElementById("chk_ssn_msg").innerHTML="<a onclick=\"chk_ssn();\">실명인증</a>";
if ( confirm('실명이 인증되지 않았습니다. 일반 회원으로 가입하시겠습니까?') )
{
document.getElementById("ssn_form").realSSN.value = "0";
document.getElementById("ssn_form").submit();
}
}
}
}
}

send( "name="+ name +"&ssn1="+ ssn1 + "&ssn2=" + ssn2 );
}
}
catch ( e)
{

}

}
}
</script>
<form>
이름:<input type="text" name="name" id="name" /><br />
주민번호앞: <input type="text" name="ssn1" id="ssn1" maxlength="6" /><br />
주민번호뒤:<input type="password" name="ssn2" id="ssn2" maxlength="7" /><br />
메세지:<span id="chk_ssn_msg"><a onclick="chk_ssn();" style="cursor:pointer;cursor:hand">실명확인</a></span>
</form>
</body>
</html>


#######################################

chk_ssn.php

#######################################

<?
include "../inc/funct/common.inc.php";
include "../inc/funct/db_class.inc.php";


//가입 유저인지 확인 (중복가입 금지)
/*
$que = "SELECT user_id FROM _member_login WHERE ssn='".$_POST['ssn1'].$_POST['ssn2']."'";
$rs = $db->ExecQuery($que);

$chk_num = $db->GetNumrows($rs);
*/
if ( $chk_num > 0 ) {
/*
$id = $db->GetResult($rs,0,0);
echo "99|".$id;
*/
}
else {
$host = "210.207.91.246"; //신용평가원 아이피
$uri = "/servlet/name_check"; //POST 데이타 전송할 URI
$name = iconv( "UTF-8","EUC-KR",$_POST['name']);

/** 수정 **/
$ok_url = "http://okurl";//중요하지 않음
$referer_page = "http://신평에 등록된 실명인증확인 페이지";
$siren_id = "siren 아이디";
/** 수정 **/



$jumin1 = $_POST['ssn1'];
$jumin2 = $_POST['ssn2'];

$reqbody =
"id=$siren_id&name=".urlencode( $name ).
"&jumin1=$jumin1".
"&jumin2=$jumin2".
"&ok_url=".urlencode($ok_url); // 리턴주소 별로 중요하지 않음

$contentlength = strlen($reqbody);

$reqheader = "POST $uri HTTP/1.0\r\n".
"Host: name.siren24.com\r\n".
"Content-Type: application/x-www-form-urlencoded\r\n".
"Referer: $referer_page\r\n".
"Content-Length: $contentlength\r\n\r\n".
"$reqbody\r\n";

$fp = fsockopen( $host , 80 , $err , $err2);
fputs($fp, $reqheader);

$tmp="x";

while ($tmp!="") {
$tmp = $buffer = fgets($fp, 4096);

if (preg_match('/name=result/',$buffer,$aMatch)) {
preg_match('/value=\\"([^\\"]*)\\"/',$buffer,$aMatch);
$result = $aMatch[1];
}

if (preg_match('/<font>/',$buffer,$aMatch)) {
preg_match('/<font>([^\\"]*)\<\/font>/',$buffer,$aMatch2);
$result = $aMatch2[1];
}
//echo $buffer;
}

fclose($fp);
?>
<?

if (!is_numeric( $result ) ) {
$result="0";
}

echo (int)$result;
}
?>


#####################<div class='small'>[이 게시물은 관리자님에 의해 2011-10-31 17:12:10 PHP & HTML에서 이동 됨]</div>
|

댓글 1개

ajax 코드로 처리하면 쉬운것을 이전에 왜 그리 페이지 이동을 해서 한글이름 깨지고 ㅜ.ㅜ
동생넘이 asp로 짜면서 ajax코드로 금방 처리해버리더군요.. 헉~! 하는 말밖에.. 덕분에 한가지 배웠지만요..
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
19년 전 조회 2,609
19년 전 조회 2,920
19년 전 조회 4,499
19년 전 조회 2,423
19년 전 조회 2,444
19년 전 조회 3,480
19년 전 조회 3,150
19년 전 조회 2,803
19년 전 조회 2,046
19년 전 조회 1,771
19년 전 조회 2,873
19년 전 조회 1,718
19년 전 조회 2,310
19년 전 조회 3,950
19년 전 조회 3,729
19년 전 조회 3,449
19년 전 조회 3,401
19년 전 조회 1,562
19년 전 조회 1,930
19년 전 조회 1,853
19년 전 조회 2,519
19년 전 조회 4,616
19년 전 조회 2,750
19년 전 조회 1,916
19년 전 조회 1,925
19년 전 조회 1,812
19년 전 조회 2,553
19년 전 조회 8,173
19년 전 조회 2,722
19년 전 조회 2,787
19년 전 조회 3,039
19년 전 조회 2,194
19년 전 조회 2,208
19년 전 조회 2,173
19년 전 조회 2,067
19년 전 조회 2,257
19년 전 조회 2,511
19년 전 조회 3,077
19년 전 조회 2,329
19년 전 조회 1,905
19년 전 조회 2,829
19년 전 조회 4,996
19년 전 조회 3,494
19년 전 조회 3,450
19년 전 조회 2,973
19년 전 조회 2,396
19년 전 조회 1,484
19년 전 조회 3,133
19년 전 조회 2,008
19년 전 조회 5,369
19년 전 조회 2,428
19년 전 조회 3,428
19년 전 조회 2,851
19년 전 조회 1,759
19년 전 조회 3,877
19년 전 조회 2,415
19년 전 조회 2,295
19년 전 조회 3,019
19년 전 조회 3,293
19년 전 조회 2,495
19년 전 조회 2,260
19년 전 조회 2,325
19년 전 조회 1,995
19년 전 조회 3,086
19년 전 조회 2,011
19년 전 조회 2,044
19년 전 조회 1,699
19년 전 조회 2,207
19년 전 조회 2,185
19년 전 조회 2,478
19년 전 조회 2,874
19년 전 조회 2,383
19년 전 조회 2,452
19년 전 조회 3,502
19년 전 조회 3,214
19년 전 조회 3,204
19년 전 조회 3,014
19년 전 조회 2,028
19년 전 조회 2,340
19년 전 조회 2,230
19년 전 조회 2,056
19년 전 조회 2,496
19년 전 조회 2,411
19년 전 조회 2,795
19년 전 조회 2,172
19년 전 조회 3,499
19년 전 조회 1,966
19년 전 조회 2,574
19년 전 조회 1,594
19년 전 조회 2,823
19년 전 조회 3,063
19년 전 조회 2,147
19년 전 조회 1,984
19년 전 조회 2,463
19년 전 조회 2,377
19년 전 조회 3,069
19년 전 조회 6,748
19년 전 조회 2,703
19년 전 조회 3,174
19년 전 조회 3,076
🐛 버그신고