以下为引用的内容: // 实在无聊,突发奇想,想把PHP里面部分已经提供封装好的函数重新使用PHP实现一遍, // 于是便有了下面的代码主要实现了PHP中部分字符串处理函数,同时实现了一些PHP中 // 没有,但是同样有作用的字符串处理函数同样的这些函数,也能够使用其他语言来实 // 现,比如用C/VBScript/Perl等等,那么你就能够有一个自己的函数库. // 以下函数不一定能够成功运行,只是为了学习而已。 // // 如果无特别声明,全部是由于heiyeluren原创,要使用任何函数都请保留作者信息 /** * String Functions Reconstruct * * Copyright (c) 2005 heiyeluren * Author: heiyeluren * $Id: StringFunctions.php,v 0.1 e 2005-5-29 23:21 heiyeluren Exp $ **/ // {{{ strlen() /** * Count string length * * @param string $str need count length string variable * @return int return count result * @version v0.1 * @create 2005-5-24 * @modified 2005-5-24 * @author heiyeluren */ function strlen1($str) { if ($str == '') return 0; $count = 0; while (1) { if ($str[$count] != NULL) { $count++; continue; } else break; } return $count; } // }}} // {{{ substr() /** * Get sub string * * @param string $str need get sub string variable * @param int $start start get sub string * @param int $length need get string length * @return string return sub string * @version v0.2 * @create 2005-5-24 * @modified 2005-5-25 * @author heiyeluren */ function substr1($str, $start, $length=0) { if ($str == '') return; if ($start > strlen($str)) return; if (($length != NULL) && ($start > 0) && ($length > strlen($str)-$start)) return; if (($length != NULL) && ($start strlen($str)+$start)) return; if ($length == NULL) $length = (strlen($str) - $start); if ($start { for ($i=(strlen($str)+$start); $i { $substr .= $str[$i]; } } if ($length > 0) { for ($i=$start; $i { $substr .= $str[$i]; } } if ($length { for ($i=$start; $i { $substr .= $str[$i]; } } return $substr; } // }}} // {{{ strrev() /** * Reversal string order * * @param string $str need reversal string variable * @return string reversal string * @version v0.1 www.knowsky.com * @create 2005-5-24 * @modified 2005-5-24 * @author heiyeluren */ function strrev1($str) { if ($str == '') return 0; for ($i=(strlen($str)-1); $i>=0; $i--) { $rev_str .= $str[$i]; } return $rev_str; } // }}} // {{{ strcmp() /** * String comparison * * @param string $s1 first string * @param string $s2 second string * @return int return -1,str1 str2, str1 = str2, * return 0, other, return false * @version v0.1 * @create 2005-5-24 * @modified 2005-5-24 * @author heiyeluren */ function strcmp1($s1, $s2) { if (strlen($s1) return -1; if (strlen($s1) > strlen($s2)) return 1; for ($i=0; $i { if ($s1[$i] == $s2[$i]) continue; else return false; } return 0; } // }}} // {{{ strchr(), strstr(), strpos() /** * Find first occurrence of a string * * @param string $str parent string * @param string $substr need match sub string * @return int return find sub string at parent string first place, * f not find, return false * @version v0.4 * @create 2005-5-24 * @modified 2005-5-29 * @author heiyeluren */ function strchr1($str, $substr) { $m = strlen($str); $n = strlen($substr); if ($m return false; for ($i=0; $i { $sub = substr($str, $i, $n); if (strcmp($sub, $substr) == 0) return $i; } return false; } // }}} // {{{ str_replace() /** * Replace all occurrences of the search string with the replacement string * * @param string $substr need replace sub string variable * @param string $newsubstr new sub string * @param string $str operate parent string * @return string return replace after new parent string * @version v0.2 * @create 2005-5-24 * @modified 2005-5-29 * @author heiyeluren */ function str_replace1($substr, $newsubstr, $str) { $m = strlen($str); $n = strlen($substr); $x = strlen($newsubstr); if (strchr($str, $substr) == false) return false; for ($i=0; $i { $i = strchr($str, $substr); $str = str_delete($str, $i, $n); $str = str_insert($str, $i, $newstr); } return $str; } // }}} /************ 以下串处理函数是PHP中没有的,自己写着玩 ***************/ // {{{ insert_str(), delete_str(), index_str() /** * Basic string operate * * @param string $str need get sub string variable * @param int $start start get sub string * @param int $length need get string length * @return string return sub string * @version v0.1 * @create 2005-5-24 * @modified 2005-5-24 * @author heiyeluren */ function str_insert($str, $i, $substr) { for($j=0; $j { $startstr .= $str[$j]; } for ($j=$i; $j { $laststr .= $str[$j]; } $str = ($startstr . $substr . $laststr); return $str; } function str_delete($str, $i, $j) { for ($c=0; $c { $startstr .= $str[$c]; } for ($c=($i+$j); $c { $laststr .= $str[$c]; } $str = ($startstr . $laststr); return $str; } // }}} // {{{ strcpy() /** * Use designate sub string replace string * * @param string $str need get sub string variable * @param int $start start get sub string * @param int $length need get string length * @return string return sub string * @version v0.1 * @create 2005-5-27 * @modified 2005-5-27 * @author heiyeluren */ function strcpy($s1, $s2) { if (strlen($s1) == NULL) return; if (!isset($s2)) return; for ($i=0; $i { $s2[] = $s1[$i]; } return $s2; } // }}} // {{{ strcat() /** * Use designate sub string replace string * * @param string $str need get sub string variable * @param int $start start get sub string * @param int $length need get string length * @return string return sub string * @version v0.1 * @create 2005-5-27 * @modified 2005-5-27 * @author heiyeluren */ function strcat($s1, $s2) { if (!isset($s1)) return; if (!isset($s2)) return; $newstr = $s1 . $s2; return $newsstr; } // }}} // {{{ php_encode(), php_decode() /** * Simple string encode/decode function * * @param string $str コード/エンコード文字列変数が必要 * @文字列コード/文字列の後のエンコードを返す * @バージョン v0.2 * @create 2005-3-11 * @modified 2005-5-24 * @作者 heiyeluren */ /* 文字列エンコード関数 */ 関数 php_encode($str) { if ($str=='' && strlen($str)>128) false を返す; for($i=0; $i { $c = ord($str[$i]); if ($c>31 && $c $c += 20; if ($c>106 && $c $c -= 75; $word = chr($c); $s .= $word; } $s を返す; } /* 文字列デコード関数 */ 関数 php_decode($str) { if ($str=='' && strlen($str)>128) false を返す; for($i=0; $i { $c = ord($word); if ($c>106 && $c $c = $c-20; if ($c>31 && $c $c = $c+75; $word = chr($c); $s .= $word; } $s を返す; } // }}} // {{{ php_encrypt(), php_decrypt() /** * 単純な文字列暗号化/復号化関数 * * @param string $str には暗号化文字列変数が必要です * @return string 文字列の後に暗号化/復号化します * @バージョン v0.1 * @create 2005-5-27 * @modified 2005-5-29 * @作者 heiyeluren */ /* 暗号鍵を定義します */ $encrypt_key = 'abcdefghijklmnopqrstuvwxyz1234567890'; $decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359'; /* 文字列暗号化関数 */ 関数 php_encrypt($str) { グローバル $encrypt_key、$decrypt_key; if (strlen($str) == 0) false を返す; for ($i=0; $i { for ($j=0; $j { if ($str[$i] == $encrypt_key[$j]) { $enstr .= $decrypt_key[$j]; 休憩; } } } $enstr; を返す} /* 文字列復号化関数 */ 関数 php_decrypt($str) { グローバル $encrypt_key、$decrypt_key; if (strlen($str) == 0) false を返す; for ($i=0; $i { for ($j=0; $j { if ($str[$i] == $decrypt_key[$j]) { $enstr .= $encrypt_key[$j]; 休憩; } } } $enstr; を返す} // }}} |

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

WebStorm Mac版
便利なJavaScript開発ツール

ドリームウィーバー CS6
ビジュアル Web 開発ツール

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。
