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,601
19년 전 조회 2,911
19년 전 조회 4,491
19년 전 조회 2,417
19년 전 조회 2,436
19년 전 조회 3,472
19년 전 조회 3,144
19년 전 조회 2,795
19년 전 조회 2,038
19년 전 조회 1,763
19년 전 조회 2,868
19년 전 조회 1,711
19년 전 조회 2,303
19년 전 조회 3,944
19년 전 조회 3,722
19년 전 조회 3,442
19년 전 조회 3,395
19년 전 조회 1,555
19년 전 조회 1,923
19년 전 조회 1,846
19년 전 조회 2,513
19년 전 조회 4,608
19년 전 조회 2,745
19년 전 조회 1,910
19년 전 조회 1,917
19년 전 조회 1,804
19년 전 조회 2,544
19년 전 조회 8,166
19년 전 조회 2,713
19년 전 조회 2,779
19년 전 조회 3,031
19년 전 조회 2,186
19년 전 조회 2,202
19년 전 조회 2,164
19년 전 조회 2,059
19년 전 조회 2,248
19년 전 조회 2,504
19년 전 조회 3,069
19년 전 조회 2,322
19년 전 조회 1,896
19년 전 조회 2,820
19년 전 조회 4,988
19년 전 조회 3,487
19년 전 조회 3,445
19년 전 조회 2,966
19년 전 조회 2,389
19년 전 조회 1,479
19년 전 조회 3,126
19년 전 조회 2,000
19년 전 조회 5,363
19년 전 조회 2,417
19년 전 조회 3,419
19년 전 조회 2,845
19년 전 조회 1,752
19년 전 조회 3,872
19년 전 조회 2,407
19년 전 조회 2,290
19년 전 조회 3,011
19년 전 조회 3,287
19년 전 조회 2,488
19년 전 조회 2,253
19년 전 조회 2,319
19년 전 조회 1,988
19년 전 조회 3,081
19년 전 조회 2,005
19년 전 조회 2,038
19년 전 조회 1,690
19년 전 조회 2,202
19년 전 조회 2,177
19년 전 조회 2,471
19년 전 조회 2,867
19년 전 조회 2,374
19년 전 조회 2,442
19년 전 조회 3,495
19년 전 조회 3,206
19년 전 조회 3,197
19년 전 조회 3,005
19년 전 조회 2,021
19년 전 조회 2,333
19년 전 조회 2,222
19년 전 조회 2,051
19년 전 조회 2,489
19년 전 조회 2,406
19년 전 조회 2,790
19년 전 조회 2,165
19년 전 조회 3,493
19년 전 조회 1,959
19년 전 조회 2,568
19년 전 조회 1,587
19년 전 조회 2,818
19년 전 조회 3,057
19년 전 조회 2,141
19년 전 조회 1,979
19년 전 조회 2,454
19년 전 조회 2,370
19년 전 조회 3,062
19년 전 조회 6,741
19년 전 조회 2,697
19년 전 조회 3,167
19년 전 조회 3,067
🐛 버그신고