>백엔드 개발 >PHP 튜토리얼 >utf8 인코딩 규칙에 따라 문자열을 가로채는 기능(sub_str의 utf8 버전)

utf8 인코딩 규칙에 따라 문자열을 가로채는 기능(sub_str의 utf8 버전)

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB원래의
2016-07-25 09:03:341123검색
  1. /*
  2. * 功能: 作用跟substr一样,除了它不会造成乱码
  3. * 参数:
  4. * 返回:
  5. */
  6. function utf8_substr( $str , $start , $length=null ){
  7. // 先正常截取一遍.
  8. $res = substr( $str , $start , $length );
  9. $strlen = strlen( $str );
  10. /* 接着判断头尾各6字节是否完整(不残缺) */
  11. // 如果参数start是正数
  12. if ( $start >= 0 ){
  13. // 往前再截取大约6字节
  14. $next_start = $start $length; // 初始位置
  15. $next_len = $next_start 6 <= $strlen ? 6 : $strlen - $next_start;
  16. $next_segm = substr( $str , $next_start , $next_len );
  17. // 如果第1字节就不是 完整字符的首字节, 再往后截取大约6字节
  18. $prev_start = $start - 6 > 0 ? $start - 6 : 0;
  19. $prev_segm = substr( $str , $prev_start , $start - $prev_start );
  20. }
  21. // start是负数
  22. else{
  23. // 往前再截取大约6字节
  24. $next_start = $strlen $start $length; // 初始位置
  25. $next_len = $next_start 6 <= $strlen ? 6 : $strlen - $next_start;
  26. $next_segm = substr( $str , $next_start , $next_len );
  27. // 如果第1字节就不是 完整字符的首字节, 再往后截取大约6字节.
  28. $start = $strlen $start;
  29. $prev_start = $start - 6 > 0 ? $start - 6 : 0;
  30. $prev_segm = substr( $str , $prev_start , $start - $prev_start );
  31. }
  32. // 判断前6字节是否符合utf8规则
  33. if ( preg_match( '@^([x80-xBF]{0,5})[xC0-xFD]?@' , $next_segm , $bytes ) ){
  34. if ( !empty( $bytes[1] ) ){
  35. $bytes = $bytes[1];
  36. $res .= $bytes;
  37. }
  38. }
  39. // 判断后6字节是否符合utf8规则
  40. $ord0 = ord( $res[0] );
  41. if ( 128 <= $ord0 && 191 >= $ord0 ){
  42. // 往后截取 , 并加在res的前面.
  43. if ( preg_match( '@[xC0-xFD][x80-xBF]{0,5}$@' , $prev_segm , $bytes ) ){
  44. if ( !empty( $bytes[0] ) ){
  45. $bytes = $bytes[0];
  46. $res = $bytes . $res;
  47. }
  48. }
  49. }
  50. return $res;
  51. }
  52. ?>
复制代码

测试---

  1. $str = 'dfjdjf测13f试65&2数据fdj(1就mfe&……就';
  2. var_dump( utf8_substr( $str , 22 , 12 ) ); echo '
    ';
  3. var_dump( utf8_substr( $str , 22 , -6 ) ); echo '
    ';
  4. var_dump( utf8_substr( $str , 9 , 12 ) ); echo '
    ';
  5. var_dump( utf8_substr( $str , 19 , 12 ) ); echo '
    ';
  6. var_dump( utf8_substr( $str , 28 , -6 ) ); echo '
    ';
  7. ?>
复制代码

显示结果:(截取无乱码) string(12) "据fdj" string(26) "据fdj(1就mfe&…" string(13) "13f试65&2数" string(12) "数据fd" string(20) "dj(1就mfe&…"



성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.