> 백엔드 개발 > PHP 튜토리얼 > 懂PHP且懂点C的大神进来

懂PHP且懂点C的大神进来

WBOY
풀어 주다: 2016-06-23 13:53:07
원래의
1206명이 탐색했습니다.

这是个客户端C版本的解密函数,我需要一个PHP版本的加密函数,麻烦下大神,

void hdth_normal_decode(char * outstr,char * instr){	int   i=0;	int j = 0;	int len = strlen(instr);	for(i=0;i<len;i=i+2)   	{   		int   h=(instr[i]-'c');   		int   l=(instr[i+1]-'f');   		char  c=(l<<4)+(h&0xf);   		outstr[j]=c;		j++;	}   	return;}
로그인 후 복사


给个原文转为密文的例子:

原文:www.comunits.net密文:jmjmjmqhflrlplhmqlllgmfmqhqlhlgm
로그인 후 복사


回复讨论(解决方案)

先移植解密函数到 php

function hdth_normal_decode($in) {  $out = '';   $len = strlen($in);  for($i=0; $i<$len; $i+=2) {    $h = ord($in{$i}) - ord('c');    $l = ord($in{$i+1}) - ord('f');    $c = ($l << 4) + ($h & 0xf);    $out .= chr($c);  }  return $out;}
로그인 후 복사
然后求其逆运算
function hdth_normal_encode($in) {  $out = '';  $len = strlen($in);  for($i=0; $i<$len; $i++) {    $c = ord($in{$i});    $l = ($c >> 4) + ord('f');    $h = ($c & 0xf) + ord('c');    $out .= chr($h) . chr($l);  }  return $out;}
로그인 후 복사
测试一下
echo hdth_normal_encode('www.comunits.net');
로그인 후 복사
jmjmjmqhflrlplhmqlllgmfmqhqlhlgm

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿