/**
* DOMXML函数笔记
* 连接php_domxml.dll后
* 用get_defined_functions()得到domxml支持函数
*
* 目前domxml不支持非iso-8859-1以外的语言声明
* 支持
* 不支持
* 因此需要改造成这样,可能需要
* utf8_encode() utf8_decode() 函数进行处理
*
* 函数列表
* string domxml_version(void) 返回domxml的版本号
* object xmldoc(string str) 从字符串创建XML的Domdocument对象
* object xmldocfile(string filename) 从文件创建XML的Domdocument对象
* object xmltree(string str) 解析xml文档,返回树状结构,不能用domxml函数改变
* resource domxml_add_root(resource doc,string name) 添加根节点
* string domxml_dumpmem(resource doc) 将domxml对象转化为XML串。这个函数有一个问题,他会在第一个汉字前面加一个扩展ascii字符,形如nnn;
* domxml_node_attributes
* domxml_elem_get_attribute
* domxml_elem_set_attribute
* array domxml_node_children(object doc|node) 返回子节点
* domxml_node_new_child
* object domxml_node(string name) 创建一个节点节点
* domxml_node_unlink_node
* int domxml_node_set_content(resource doc,string content) 设置节点内容
* object domxml_new_xmldoc(string version) 创建新的空XML对象
* xpath_new_context
* xpath_eval
* xpath_eval_expression
* xptr_new_context
* xptr_eval
* object domxml_root(object doc) 返回根节点
* array domxml_attributes(resource note) 获取节点属性
* object domxml_get_attribute(resource doc,string name) 读取属性
* domxml_getattr
* object domxml_set_attribute(resource doc,string name,string value) 添加属性
* domxml_setattr
* array domxml_children(object doc|node) 返回子节点
* resource domxml_new_child(string name,string content) 添加子节点
* domxml_unlink_node
* set_content
* new_xmldoc
*
*/
?>
<br><?php <br>// 文档 xml源树.xml 内容<br>$testxml = '<br><?xml version="1.0" encoding="GB2312"?> <br><root><br><note>读取xml文档时,处理器将形成一个树,我们将其叫做源树。该树具有表中的各种类型的节点。<br></note><br><title>源树具有的节点</title> <br><table> <br><tr> <th>节点类型</th> <th>说明</th> </tr> <br><tr> <td>Root(根)</td> <td>这是树的根节点。可以出现在树的任何地方。根节点只具有一个子节点,子节点指的是xml文档中的文档元素节点。</td> </tr> <br><tr> <td>Element(元素)</td> <td>这种节点用于文档中的任何元素。元素节点的子节点可以是其内容的元素节点、注释节点、处理信息节点以及文本节点。</td> </tr> <br><tr> <td>Text(文本)</td> <td>文档中出现的所有文本,都分组归入到文本节点中。文本节点不可以有同为文本节点的紧接着的前或后的兄弟节点。</td> </tr> <br><tr> <td>Attribute(属性)</td> <td>每一个元素节点都有一套自己附加的属性节点。默认的属性值以与指定属性一样的方法来处理。这些节点都没有子节点。</td> </tr> <br><tr> <td>Namespace(名称)</td> <td>对于每一个以xlmns:和属性节点开头的元素,都有一个名称空格节点。这些节点没有子节点。</td> </tr> <br><tr> <td>Processing Instruction(处理指令)</td> <td>每一个处理指令都有一个单独的节点。这些节点都没有子节点。</td> </tr> <br><tr> <td>Comment(注释)</td> <td>每一个都有一个注释节点。这些节点都没有子节点。</td> </tr> <br> </table> <br></root><br>';<br><br>echo "domxml版本:".domxml_version();<br>echo "<p> </p>";<br>// xmltree domxml_dumpmem<br>$filename = "xml源树.xml";<br>//$filename = "resume.xml";<br>$fp = fopen($filename,"r"); <br>$inXML = fread($fp,filesize($filename)); <br>fclose($fp); <br>// 删除语言设定<br>//$inXML = str_replace(' encoding="GB2312"',"",$inXML);<br>$inXML = eregi_replace(' encoding="[a-z0-9_-]+"',"",$inXML);<br><br>$doc = xmltree($inXML); // 使用xmltree解析<br>$myxml = $doc->dumpmem(); // 转换成字串,头为 xml version="1.0"<br> // 如果再执行一次,头将变成 xml version="1.0" encoding="ISO-8859-1"<br>//$myxml = eregi_replace('[0-9]+;',"",$myxml); // 删除<br>echo "用xmltree解析<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br>//print_r($doc); // 可以看到整个树 亦可用var_dump($doc);<br><br>// xmldoc<br>$doc = xmldoc($inXML); <br>$myxml = $doc->dumpmem();<br>echo "用xmldoc解析<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br>//print_r($doc); // 只能看到根节点<br><br>// domxml_new_xmldoc<br>$doc = domxml_new_xmldoc("1.0");<br><br>$root = $doc->add_root("HTML");<br>$head = $root->new_child("HEAD", "");<br>$head->new_child("TITLE", "DOMXML 测试0");<br>$head->new_child("TITLE", "DOMXML 测试1");<br>$head->set_attribute("Language", "ge");<br>domxml_node_set_content($head,"ppp"); // 设置节点的内容,多次执行是叠加的<br>domxml_node_set_content($head,"ttt");<br><br>// 是乎函数名中只有1-2个"_"的函数,可作为对象的方法使用<br><br>$myxml = $doc->dumpmem();<br>echo "自定义xml<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br><br>// 节点的遍历<br>/**<br> 节点结构<br> DomElement Object<br> type = 1<br> tagname = 节点名<br> DomText Object<br> type = 3<br> content = 节内容点<br> DomCData Object<br> type = 4<br> content = 节内容点<br><br> DomProcessingInstruction Object<br> type 无<br> target = 处理指令<br> data = 参数<br><br>*/<br>$ar[] = $doc->root(); // 取得根节点<br>$ar[] = $ar[count($ar)-1]->children();<br>$ar[] = $ar[count($ar)-1][0]->children();<br><br>// 函数domxml_children() 不能返回节点参数<br>// 返回节点参数需要使用domxml_attributes()<br>//var_dump(domxml_attributes($head));<br>//print_r($ar[1][0]->attributes());<br>//print_r($ar);<br><br>function xml_dumpmem($xmldoc) {<br> static $mode = 0;<br> $xmlstr = "";<br> // 获取节点,保存在数组中<br> if(get_class($xmldoc) == "DomDocument") {<br> $xmlstr = '<?xml version="1.0" encoding="gb2312"?>'."\n";<br> if(count($xmldoc->children) == 1) // 根节点,没有其他成员<br> $docs[] = $xmldoc->root();<br> else<br> $docs = $xmldoc->children(); // 根节点,有其他成员<br> }else {<br> $docs = $xmldoc->children(); // 一般节点<br> }<br><br>// echo __LINE__."<br>";<br> foreach($docs as $doc) {<br> $attr = $doc->attributes();<br> switch($doc->type) {<br> case 1:<br> $xmlstr .= "tagname}"; // 标签头<br> if($attr) {<br> foreach($attr as $key)<br> $xmlstr .= " {$key->name}=\"{$key->value}\""; // 标签参数<br> }<br> $xmlstr .= ">"; // 标签结束<br> $xmlstr .= xml_dumpmem($doc); // 进入子节点<br> $xmlstr .= "{$doc->tagname}>"; // 闭合标签<br> break;<br> case 3:<br> $xmlstr .= $doc->content;<br> break;<br> case 4:<br> $xmlstr .= " $xmlstr .= $doc->content;<br> $xmlstr .= "]]>";<br> break;<br> default:<br> if(get_class($doc) == "DomProcessingInstruction") {<br> $xmlstr .= "{$doc->target}";<br> $xmlstr .= " {$doc->data}?>\n";<br> }<br> break;<br> }<br> }<br> return $xmlstr;<br>}<br><br>if(1) {<br> $filename = "resume.xml";<br>// $filename = "resume.xsl";<br> $filename = "xml源树.xml";<br> $fp = fopen($filename,"r"); <br> $inXML = fread($fp,filesize($filename)); <br> fclose($fp); <br> $inXML = eregi_replace(' encoding="[a-z0-9_-]+"',"",$inXML);<br>// $doc = xmltree($inXML); // 使用xmltree解析<br> $doc = xmldoc($inXML); // 使用xmldoc解析<br>}<br><br>// 不能用来解析xsl文档<br><br>$myxml = xml_dumpmem($doc);<br>echo "自己写一个dumpmem就不出错了<br>";<br>echo "<textarea cols="60" rows="5">$myxml</textarea><br>";<br>print_r($doc);<br><br>?><br>

phpsessionstrackuserdataacrossmultiplepagerequestsususingauniqueIdStoredInAcookie.here'showtomanagetheMeftically : 1) STARTASESSIONSTART_START () andSTAREDATAIN $ _SESSION.2) RegenerATERATESSESSIDIDAFTERLOGINWITHSESSION_RATERATERATES (True) TopreventSES

PHP에서 세션 데이터를 통한 반복은 다음 단계를 통해 달성 할 수 있습니다. 1. Session_start ()를 사용하여 세션을 시작하십시오. 2. $ _session 배열의 모든 키 값 쌍을 통해 Foreach 루프를 통과합니다. 3. 복잡한 데이터 구조를 처리 할 때 is_array () 또는 is_object () 함수를 사용하고 print_r ()를 사용하여 자세한 정보를 출력하십시오. 4. Traversal을 최적화 할 때 페이징을 사용하여 한 번에 많은 양의 데이터를 처리하지 않도록 할 수 있습니다. 이를 통해 실제 프로젝트에서 PHP 세션 데이터를보다 효율적으로 관리하고 사용하는 데 도움이됩니다.

이 세션은 서버 측 상태 관리 메커니즘을 통해 사용자 인증을 인식합니다. 1) 세션 생성 및 고유 ID의 세션 생성, 2) ID는 쿠키를 통해 전달됩니다. 3) ID를 통해 서버 저장 및 세션 데이터에 액세스합니다. 4) 사용자 인증 및 상태 관리가 실현되어 응용 프로그램 보안 및 사용자 경험이 향상됩니다.

tostoreauser'snameinaphpsession, startSessionstart_start (), wathsignthenameto $ _session [ 'username']. 1) useSentess_start () toinitializethesession.2) assimeuser'snameto $ _session [ 'username']

phpsession 실패 이유에는 구성 오류, 쿠키 문제 및 세션 만료가 포함됩니다. 1. 구성 오류 : 올바른 세션을 확인하고 설정합니다. 2. 쿠키 문제 : 쿠키가 올바르게 설정되어 있는지 확인하십시오. 3. 세션 만료 : 세션 시간을 연장하기 위해 세션을 조정합니다 .GC_MAXLIFETIME 값을 조정하십시오.

PHP에서 세션 문제를 디버그하는 방법 : 1. 세션이 올바르게 시작되었는지 확인하십시오. 2. 세션 ID의 전달을 확인하십시오. 3. 세션 데이터의 저장 및 읽기를 확인하십시오. 4. 서버 구성을 확인하십시오. 세션 ID 및 데이터를 출력, 세션 파일 컨텐츠보기 등을 통해 세션 관련 문제를 효과적으로 진단하고 해결할 수 있습니다.

Session_Start ()로 여러 통화를하면 경고 메시지와 가능한 데이터 덮어 쓰기가 발생합니다. 1) PHP는 세션이 시작되었다는 경고를 발행합니다. 2) 세션 데이터의 예상치 못한 덮어 쓰기를 유발할 수 있습니다. 3) Session_status ()를 사용하여 반복 통화를 피하기 위해 세션 상태를 확인하십시오.

SESSION.GC_MAXLIFETIME 및 SESSION.COOKIE_LIFETIME을 설정하여 PHP에서 세션 수명을 구성 할 수 있습니다. 1) SESSION.GC_MAXLIFETIME 서버 측 세션 데이터의 생존 시간을 제어합니다. 2) 세션 .Cookie_Lifetime 클라이언트 쿠키의 수명주기를 제어합니다. 0으로 설정하면 브라우저가 닫히면 쿠키가 만료됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구
