{"id":5500,"date":"2016-10-18T07:42:04","date_gmt":"2016-10-18T07:42:04","guid":{"rendered":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/?p=5500"},"modified":"2016-10-18T08:08:52","modified_gmt":"2016-10-18T08:08:52","slug":"%e3%82%b3%e3%83%b3%e3%83%86%e3%83%b3%e3%83%84%e3%81%ae%e6%9b%b4%e6%96%b0","status":"publish","type":"post","link":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/?p=5500","title":{"rendered":"\u6570\u5f0f\u81ea\u52d5\u63a1\u70b9\u30b3\u30f3\u30c6\u30f3\u30c4\u306e\u66f4\u65b0"},"content":{"rendered":"<p>\u4ed5\u4e8b\u306e\u8a18\u9332\u3067\u3059\u3002<\/p>\n<p>\u6b21\u671f\u3001\u6570\u5f0f\u81ea\u52d5\u63a1\u70b9\u30b3\u30f3\u30c6\u30f3\u30c4\u7528\u306b\u30b3\u30fc\u30c9\u3092\u66f8\u304d\u76f4\u3057\u3066\u3044\u307e\u3059\u3002scorm_portal \u306b\u84c4\u3048\u3089\u308c\u3066\u3044\u308b\u6559\u6750\u3082\u5185\u5bb9\u3092\u5909\u66f4\u3057\u306a\u3051\u308c\u3070\u306a\u308a\u307e\u305b\u3093\u3002\u305d\u306e\u305f\u3081\u306e\u30c4\u30fc\u30eb\u3092\u66f8\u304d\u307e\u3057\u305f\u3002<\/p>\n<p>\u5927\u304d\u306a\u5909\u66f4\u70b9\u3068\u3057\u3066\u306f\u3001\u3053\u308c\u307e\u3067\u6697\u53f7\u5316\u3057\u305f\u307e\u307e\u4fdd\u5b58\u3057\u3066\u3044\u305f\u6b63\u89e3\u3092\u5fa9\u53f7\u5316\u3057\u3066\u53ef\u8aad\u306e\u72b6\u614b\u3067\u4fdd\u5b58\u3059\u308b\u3053\u3068\u306b\u5909\u66f4\u3057\u307e\u3057\u305f\u3002\u305d\u308c\u306f\u3001\u4eca\u56deOS\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u30a2\u30c3\u30d7\u306b\u3068\u3082\u306a\u3063\u3066\u6697\u53f7\u5316\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u52d5\u304b\u306a\u304f\u306a\u3063\u3066\u4ed6\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u3078\u306e\u5909\u66f4\u3092\u4f59\u5100\u306a\u304f\u3055\u308c\u305f\u304b\u3089\u3067\u3059\u3002\u6697\u53f7\u5316\u3057\u305f\u307e\u307e\u4fdd\u5b58\u3057\u3066\u304a\u304f\u3068\u5c06\u6765\u5371\u967a\u3067\u3059\u3002\u3053\u308c\u304b\u3089\u306f\u3001\u6559\u6750\u3068\u3057\u3066\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3059\u308b\u3068\u304d\u306b\u6697\u53f7\u5316\u3057\u307e\u3059\u3002\u4ed6\u306e\u5909\u66f4\u70b9\u306f\u3001\u63a1\u70b9php\u306eURL\u306e\u5909\u66f4\u3084\u3001\u914d\u70b9\u30bf\u30b0\u306e\u8ffd\u52a0\u306a\u3069\u3067\u3057\u305f\u3002\u4ee5\u4e0b\u306b\u3001\u305d\u306e\u30b3\u30fc\u30c9\u3092\u3042\u3052\u307e\u3059\u3002\u3044\u3063\u305f\u3093\u30c7\u30fc\u30bf\u30fc\u30d9\u30fc\u30b9\u3092\u30b3\u30d4\u30fc\u3057\u305f\u3042\u3068\u3001\u4fee\u6b63\u3092\u52a0\u3048\u307e\u3059\u3002<\/p>\n<p>\u3053\u308c\u3092\u4f7f\u3063\u3066\u3001\u4eca\u5ea6\u306e3\u6708\u306b\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u4fee\u6b63\u3057\u307e\u3059\u3002<\/p>\n<pre><code style=\"color: midnightblue;\">&lt;?php\r\n\r\n\/\/ scorm_portal \u306e\u30c7\u30fc\u30bf\u3092\u4fee\u6b63\u3059\u308b\u30d7\u30ed\u30b0\u30e9\u30e0\u3002\u3053\u308c\u307e\u3067\u306f\u3001\u6b63\u89e3\u304c\u6697\u53f7\u5316\u3055\u308c\u305f\u307e\u307e\u3060\u3063\u305f\u304c\r\n\/\/ \u305d\u308c\u3067\u306f\u3001OS\u306e\u5909\u66f4\u306a\u3069\u306b\u3088\u3063\u3066\u3001\u6697\u53f7\u5316\u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u52d5\u304b\u306a\u304f\u306a\u3063\u305f\u6642\u306b\u5371\u967a\u3067\u3042\u308b\u3002\u305d\u306e\u305f\u3081\u3001\r\n\/\/ \u3053\u308c\u304b\u3089\u306f\u3001\u6697\u53f7\u5316\u305b\u305a\u306b\u6b63\u89e3\u3092\u8a18\u9332\u3059\u308b\u3002\u3053\u306e\u30d7\u30ed\u30b0\u30e9\u30e0\u3067\u3001\u6697\u53f7\u5316\u3055\u308c\u305f\u6b63\u89e3\u3092\u5fa9\u53f7\u3057\u3066\u3001\r\n\/\/ \u30c7\u30fc\u30bf\u3092\u65b0\u3057\u3044 scorm_portal \u306b\u9069\u5408\u3059\u308b\u3088\u3046\u306b\u4fee\u6b63\u3059\u308b\u3002\r\n\r\n\/\/ \u914d\u70b9\u30bf\u30b0\u3082\u8ffd\u52a0\r\n\r\n\/\/ \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u63a5\u7d9a\r\n$DB = mysqli_connect( 'localhost', '\u30e6\u30fc\u30b6\u30fc\u540d', '\u30d1\u30b9\u30ef\u30fc\u30c9', 'scorm_portal') or die(mysqli_connect_error());\r\n\r\nmysqli_set_charset($DB, 'utf8');\r\n\/\/ \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u63a5\u7d9a\r\n$DB2 = mysqli_connect( 'localhost', '\u30e6\u30fc\u30b6\u30fc\u540d', '\u30d1\u30b9\u30ef\u30fc\u30c9', 'scorm_portal_copy') or die(mysqli_connect_error());\r\n\r\nmysqli_set_charset($DB2, 'utf8');\r\n\r\n\/\/ \u30b3\u30d4\u30fc\u5148($DB2)\u306e\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306e\u5185\u5bb9\u3092\u524a\u9664\u3059\u308b\r\n\r\n$sql = \"SHOW TABLES;\";\r\n$result = mysqli_query($DB2, $sql) or die(mysqli_error($DB2));\r\n\r\n$rows = mysqli_num_rows($result);\r\n\r\necho \"\u30b3\u30d4\u30fc\u5148\u306eTable \".$rows.\" \u500b\u3092\u524a\u9664\u3057\u307e\u3059\\n\";\r\nfor ($i = 0; $i &lt; $rows; $i = $i + 1) {\r\n\r\n$row = mysqli_fetch_array($result);\r\n\r\n\/\/var_dump($row[0]);\r\n\r\n$sql = \"DROP TABLE `\".$row[0].\"`;\";\r\n\r\nmysqli_query($DB2, $sql) or die(mysqli_error($DB2));\r\n\r\necho \"DROP \".$row[0].\"\\n\";\r\n\r\n}\r\n\r\n\/\/ \u30b3\u30d4\u30fc\u3059\u308b\r\n\r\n$sql = \"SHOW TABLES;\";\r\n$result = mysqli_query($DB, $sql) or die(mysqli_error($DB));\r\n\r\n$rows = mysqli_num_rows($result);\r\n\r\necho \"Table \".$rows.\" \u500b\u3092\u30b3\u30d4\u30fc\u3057\u307e\u3059\\n\";\r\nfor ($i = 0; $i &lt; $rows; $i = $i + 1) {\r\n\r\n$row = mysqli_fetch_array($result);\r\n\r\n\/\/var_dump($row[0]);\r\n\r\n\/\/$sql = \"DROP TABLE `\".$row[0].\"`;\";\r\n\r\n$a_table_name = \"`\".$row[0].\"`\";\r\n\r\n$sql = \"CREATE TABLE scorm_portal_copy.$a_table_name LIKE scorm_portal.$a_table_name\";\r\n\r\nmysqli_query($DB2, $sql) or die(mysqli_error($DB2));\r\n$sql = \"INSERT INTO scorm_portal_copy.$a_table_name SELECT * FROM scorm_portal.$a_table_name\";\r\n\r\nmysqli_query($DB2, $sql) or die(mysqli_error($DB2));\r\necho \"copy \".$row[0].\"\\n\";\r\n\r\n}\r\n\r\n\/\/ author table \u540d\u3060\u3051\u3092\u53d6\u5f97\u3057\u3001\u914d\u5217\u306b\u5165\u308c\u308b\r\n$sql = \"SHOW TABLES LIKE 'table_%';\";\r\n$result = mysqli_query($DB, $sql) or die(mysqli_error($DB));\r\n\r\n$rows = mysqli_num_rows($result);\r\n\r\necho \"author \u306e table \u306f\".$rows.\" \u500b\u3042\u308a\u307e\u3059\\n\";\r\n\r\n$table_ary = array();\r\nfor ($i = 0; $i &lt; $rows; $i = $i + 1) {\r\n\r\n$row = mysqli_fetch_array($result);\r\n$table_ary[] = $row[0];\r\n\r\n}\r\n\r\n$table_num = $rows;\r\n\r\n\/\/var_dump($table_ary);\r\n\r\n\/\/ \u4f5c\u696d\u30d5\u30a9\u30eb\u30c0\u30fc\u3092\u7528\u610f\u3059\u308b\r\n\r\n$stamp = microtime();\r\nlist($msec, $sec) = explode(\" \", $stamp);\r\n\r\n$mustamp = $stamp*1000000;\r\n\r\n$timestamp = $sec.$mustamp;\r\n\r\n$head = \"tmp\".$timestamp;\r\n\r\n$foldername = mb_convert_encoding($head, \"UTF-8\", \"auto\");\r\n\r\npassthru(\"mkdir -p \/var\/www\/html\/temporary\/$foldername\/tmp\/\");\r\n\r\necho \"\u4f5c\u696d\u30d5\u30a9\u30eb\u30c0\u30fc $foldername \u3092\u4f5c\u6210\\n\";\r\n\r\n\/\/ \u305d\u308c\u305e\u308c\u306e\u30b3\u30f3\u30c6\u30f3\u30c4\u306e\u6b63\u89e3\u3092\u5fa9\u53f7\u3059\u308b\r\n\r\n\/\/ \u6697\u53f7\u306e\u70ba\r\n\r\nrequire_once '\/var\/www\/html\/Crypt_RSA-1.2.1\/RSA.php';\r\n\r\nfunction check_error(&amp;$obj)\r\n{\r\nif ($obj-&gt;isError()){\r\n$error = $obj-&gt;getLastError();\r\nswitch ($error-&gt;getCode()) {\r\ncase CRYPT_RSA_ERROR_WRONG_TAIL :\r\n\/\/ nothing to do\r\nbreak;\r\ndefault:\r\n\/\/ echo error message and exit\r\necho 'error: ', $error-&gt;getMessage();\r\nexit;\r\n}\r\n}\r\n}\r\n\r\n$file = '\/var\/www\/key\/key.txt';\r\n\r\n$keyxml = simplexml_load_string(file_get_contents($file));\r\n\r\nfor ($i = 0; $i &lt; $table_num; $i = $i + 1) {\r\n\r\n$a_table_name = \"`\".$table_ary[$i].\"`\";\r\n\r\n$sql = \"SELECT id, title, zip FROM $a_table_name;\";\r\n\r\n$result = mysqli_query($DB2, $sql) or die(mysqli_error($DB2));\r\n\r\n$rows = mysqli_num_rows($result);\r\n\r\necho \"$table_ary[$i] has \".$rows.\" rows.\\n\";\r\nfor ($j = 0; $j &lt; $rows; $j = $j + 1){\r\n\r\n$row = mysqli_fetch_array($result);\r\n\r\n$id = $row['id'];\r\n\r\n$a_file = fopen(\"\/var\/www\/html\/temporary\/$foldername\/tmp.zip\",\"w\");\r\n\r\nfwrite($a_file, $row['zip']);\r\n\r\nfclose($a_file);\r\n\r\npassthru(\"cd \/var\/www\/html\/temporary\/$foldername\/; unzip -q \/var\/www\/html\/temporary\/$foldername\/tmp.zip -d \/var\/www\/html\/temporary\/$foldername\/tmp\/\");\r\ndecode_TAns($foldername);\r\n\r\npassthru(\"cd \/var\/www\/html\/temporary\/$foldername\/tmp ; zip -q -r \/var\/www\/html\/temporary\/$foldername\/new.zip .\/configfile.xml .\/glossary .\/html\");\r\n\r\n$zipbinary = file_get_contents(\"\/var\/www\/html\/temporary\/$foldername\/new.zip\");\r\n\r\n$zipbinary = mysqli_real_escape_string($DB2, $zipbinary);\r\n$sql = \"UPDATE $a_table_name SET zip='$zipbinary' WHERE id='$id'\";\r\n$result_UPDATE = mysqli_query($DB2, $sql) or die(mysqli_error($DB));\r\n\r\necho \"changed \".$row['title'].\"\\n\";\r\n\/\/ \u4f5c\u696d\u30d5\u30a1\u30a4\u30eb\u3092\u6d88\u3059\r\n\r\npassthru(\"rm -r \/var\/www\/html\/temporary\/$foldername\/*\");\r\n\/\/break 2;\r\n\r\n}\r\n}\r\nfunction decode_TAns($foldername) {\r\n\r\nglobal $keyxml;\r\n\/\/ TAns \u3092\u5fa9\u53f7\r\n\r\n$config_text = file_get_contents(\"\/var\/www\/html\/temporary\/$foldername\/tmp\/configfile.xml\");\r\n$config_xml = simplexml_load_string($config_text);\r\n\/\/$file = '\/var\/www\/key\/key.txt';\r\n\/\/$keyxml = simplexml_load_string(file_get_contents($file));\r\n\/\/ private key \u3092\u63a2\u3059\r\nif ($config_xml-&gt;key) {\r\n$public_key = (string) $config_xml-&gt;key;\r\n\r\n$key_num = 0;\r\n\r\nfor ($i = 0; $i &lt; $keyxml-&gt;key-&gt;count(); $i++) {\r\n\r\nif (((string) $keyxml-&gt;key[$i]-&gt;public) == $public_key) {\r\n$key_num = intval($keyxml-&gt;key[$i]-&gt;number);\r\n}\r\n}\r\n\r\n} else {\r\n\r\n$key_num = 0;\r\n$public_key = (string) $keyxml-&gt;key[$key_num]-&gt;public;\r\n\r\n}\r\n\r\n$key2 = Crypt_RSA_Key::fromString($keyxml-&gt;key[$key_num]-&gt;private);\r\n\r\n$rsa_obj = new Crypt_RSA;\r\ncheck_error($rsa_obj);\r\n\/\/Check encrypting\/decrypting function's behaviour\r\n$rsa_obj-&gt;setParams(array('dec_key' =&gt; $key2));\r\ncheck_error($rsa_obj);\r\n$i = 0;\r\n\r\nforeach ($config_xml-&gt;question as $q) {\r\n$i = $i + 1;\r\n\r\n$someobj = new find_question();\r\n\r\n$q = $someobj-&gt;action($rsa_obj,$q);\r\n}\r\n$config_xml-&gt;version = '3.0';\r\n\r\n$config_xml-&gt;cgi-&gt;url = \"\/php_simple_question_recursion\/answertest_3_0.php\";\r\n\r\n$config_xml-&gt;key = '';\r\n\r\n$config_string = $config_xml-&gt;asXML();\r\n\r\n$config_string = str_replace('&lt;key&gt;&lt;\/key&gt;','&lt;phpseclibKey&gt;&lt;\/phpseclibKey&gt;',$config_string);\r\n\r\n$config_string = str_replace('&lt;size&gt;',\"&lt;Allotment&gt;5&lt;\/Allotment&gt;\\n&lt;size&gt;\",$config_string);\r\n\r\n\/\/echo $config_string;\r\n\r\n$target = fopen(\"\/var\/www\/html\/temporary\/$foldername\/tmp\/configfile.xml\",\"w\");\r\n\r\nfputs($target, $config_string);\r\n\r\nfclose($target);\r\n\r\n\/\/ html \u30d5\u30a9\u30eb\u30c0\u30fc\u306e\u4e2d\u306e configfile.xml \u3092\u4fee\u6b63\r\n\r\n$config_text = file_get_contents(\"\/var\/www\/html\/temporary\/$foldername\/tmp\/html\/configfile.xml\");\r\n\r\n$config_xml = simplexml_load_string($config_text);\r\n$config_xml-&gt;version = '3.0';\r\n\r\n$config_xml-&gt;cgi-&gt;url = \"\/php_simple_question_recursion\/answertest_3_0.php\";\r\n\r\n$config_xml-&gt;key = '';\r\n\r\n$config_string = $config_xml-&gt;asXML();\r\n\r\n$config_string = str_replace('&lt;key&gt;&lt;\/key&gt;','&lt;phpseclibKey&gt;&lt;\/phpseclibKey&gt;',$config_string);\r\n$target = fopen(\"\/var\/www\/html\/temporary\/$foldername\/tmp\/html\/configfile.xml\",\"w\");\r\n\r\nfputs($target, $config_string);\r\n\r\nfclose($target);\r\n} \/\/ decode_TAns\r\nclass find_question {\r\n\r\nfunction __constructor() {\r\n}\r\n\r\npublic function action($rsa_obj,$q) {\r\n$tans =(string)$q-&gt;TAns;\r\n\r\n$q-&gt;TAns = trim(str_decode($rsa_obj,$tans));\r\n\r\nif ($q-&gt;question) {\r\n\r\n$newq = $q-&gt;question;\r\n\r\n$someobj = new find_question();\r\n\r\n$newq = $someobj-&gt;action($rsa_obj,$newq);\r\n\r\n}\r\n\r\nreturn $q;\r\n}\r\n\r\n} \/\/ end of find_question\r\nfunction str_decode($rsa_obj,$str) {\r\n\r\n$rtext = (string)$rsa_obj-&gt;decrypt($str);\r\n\r\nreturn $rtext;\r\n}\r\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>\u4ed5\u4e8b\u306e\u8a18\u9332\u3067\u3059\u3002 \u6b21\u671f\u3001\u6570\u5f0f\u81ea\u52d5\u63a1\u70b9\u30b3\u30f3\u30c6\u30f3\u30c4\u7528\u306b\u30b3\u30fc\u30c9\u3092\u66f8\u304d\u76f4\u3057\u3066\u3044\u307e\u3059\u3002sc &#8230; <a class=\"more-link\" href=\"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/?p=5500\">Read More &raquo;<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4],"tags":[],"class_list":["post-5500","post","type-post","status-publish","format-standard","hentry","category-column"],"_links":{"self":[{"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/5500","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=5500"}],"version-history":[{"count":11,"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/5500\/revisions"}],"predecessor-version":[{"id":5511,"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=\/wp\/v2\/posts\/5500\/revisions\/5511"}],"wp:attachment":[{"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=5500"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=5500"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/zairyo.susi.oita-u.ac.jp\/wordpress\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=5500"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}