Doc.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362
  1. <?php
  2. namespace Manage\Src;
  3. use Dever;
  4. class Doc
  5. {
  6. private $data;
  7. public function __construct()
  8. {
  9. $this->load();
  10. }
  11. public function nav()
  12. {
  13. return $this->data['nav'];
  14. }
  15. public function info()
  16. {
  17. return $this->data['nav'][$this->db];
  18. }
  19. public function doc()
  20. {
  21. return $this->doc;
  22. }
  23. public function menu()
  24. {
  25. return $this->data['data'];
  26. }
  27. private function load()
  28. {
  29. $this->type = Dever::input('type', 'db');
  30. $this->db = Dever::input('db');
  31. $type = 'load_' . $this->type;
  32. $this->$type();
  33. }
  34. private function create_nav($list, $num = 0)
  35. {
  36. $this->data['nav'] = array();
  37. $i = 0;
  38. foreach ($list as $k => $v) {
  39. if ($v['order'] > $num) {
  40. if (!$this->db && $i == 0) {
  41. $this->db = $k;
  42. }
  43. $this->data['nav'][$k] = array
  44. (
  45. 'name' => $v['lang'],
  46. 'link' => Dever::url('doc/view?type=' . $this->type . '&db=' . $k, 'manage'),
  47. 'class' => $this->db == $k ? 'active' : '',
  48. );
  49. $i++;
  50. }
  51. }
  52. if (!$this->data['nav']) {
  53. Dever::alert('没有该数据项');
  54. }
  55. }
  56. private function load_db()
  57. {
  58. $list = Dever::load('manage/project.get');
  59. $this->create_nav($list);
  60. if (isset($this->data['nav'][$this->db])) {
  61. $this->doc = '介绍' . $this->data['nav'][$this->db]['name'] . '项目下的数据结构与对外的数据接口';
  62. $database = Dever::load('manage/database');
  63. $data = $database->config($this->db);
  64. $this->data['data'] = array();
  65. $table = array
  66. (
  67. '方法名' => '参数',
  68. '查询表中所有数据(select)' => array
  69. (
  70. 'option_col' => '可选参数,col换成表的字段',
  71. ),
  72. '统计表中所有数据(total)' => array
  73. (
  74. 'option_col' => '可选参数,col换成表的字段',
  75. ),
  76. '查询表中一条数据(find)' => array
  77. (
  78. 'where_id' => '必填参数,表主键',
  79. ),
  80. '插入数据(insert)' => array
  81. (
  82. 'add_col' => '必填参数,col换成表的字段',
  83. ),
  84. '删除数据(delete)' => array
  85. (
  86. 'where_id' => '必填参数,表主键',
  87. ),
  88. '更新数据(update)' => array
  89. (
  90. 'where_id' => '必填参数,表主键',
  91. 'set_col' => '必填参数,col换成表的字段',
  92. ),
  93. );
  94. $this->data['data']['api']['name'] = '通用数据接口';
  95. $this->data['data']['api']['content'] = '<pre>所有数据接口,均使用:Dever::db("项目名/表名")->方法名(参数)调取<br />例如:Dever::db("manage/role")->select(array("option_name" => "超级管理员"))</pre>';
  96. $this->data['data']['api']['content'] .= Dever::table($table);
  97. foreach ($data as $k => $v) {
  98. $this->data['data'][$k]['content'] = '<h3>数据结构:</h3>';
  99. $this->data['data'][$k]['content'] .= $v['manage']['struct'];
  100. //$this->data['data'][$k]['name'] = $v['lang'];
  101. //$this->data['data'][$k]['name'] = $this->db . '_' . $v['name'] . '('.$v['lang'].'表)';
  102. $this->data['data'][$k]['name'] = $v['name'] . '(' . $v['lang'] . '表)';
  103. unset($v['request']['list']);
  104. if (isset($v['request']) && $v['request']) {
  105. $this->data['data'][$k]['content'] .= '<h3>数据接口:</h3>';
  106. $this->data['data'][$k]['content'] .= Dever::table($v['request']);
  107. }
  108. }
  109. return $this->data['data'];
  110. }
  111. return array();
  112. }
  113. private function load_mysql()
  114. {
  115. $list = array
  116. (
  117. 'guifan' => array
  118. (
  119. 'lang' => '规范',
  120. 'order' => 1,
  121. ),
  122. 'sql' => array
  123. (
  124. 'lang' => '优化',
  125. 'order' => 1,
  126. ),
  127. 'example' => array
  128. (
  129. 'lang' => '样例',
  130. 'order' => 1,
  131. ),
  132. 'function' => array
  133. (
  134. 'lang' => '常用函数',
  135. 'order' => 1,
  136. ),
  137. );
  138. $this->create_nav($list);
  139. if (isset($this->data['nav'][$this->db])) {
  140. $this->doc = '介绍Mysql' . $this->data['nav'][$this->db]['name'] . '里的一些常见问题';
  141. $this->data['data'] = array();
  142. $data['guifan'] = array
  143. (
  144. 'mm' => array
  145. (
  146. 'name' => '命名和编码',
  147. 'content' => '<pre>
  148. 库名、表名、字段名必须使用小写字母,多个单词用“_”分割(例如表名:user_comment)
  149. 库名、表名、字段名称禁止使用mysql保留字命名 ,比如:select,insert,order,group,delete,limit等等
  150. 建库和建表的编码和字符集分别是utf8和utf8_general_ci
  151. 使用dever建立表时,请遵守dever框架规范
  152. </pre>',
  153. ),
  154. 'sql' => array
  155. (
  156. 'name' => '建库建表',
  157. 'content' => "<pre>
  158. 表类型如果读多写极少(比如文章)可以用myisam;读写都较多或者需要用到事物的情况用innodb;
  159. 其它情况两个都可以选择
  160. 字段必须有详细注释,并且有多值的字段要列出所有值的含义(比如状态status字段)
  161. 字段必须为NOT NULL和设置default值
  162. 字段固定长度的短字符用char(例如md5后的密码),长度不固定的用varchar,char或者varchar能满足的不要使用text
  163. 大字段类型要慎用(TEXT、BLOB等等)
  164. 字段能用int类型都使用int型存储
  165. <pre>例如:
  166. IP可转换成int后存储
  167. 日期和时间可用int存储
  168. enum类型可使用tinyint存储</pre>
  169. 密码字段不能明文存储
  170. 建表就得考虑索引,而不是发现sql慢了才加索引
  171. 单个表字段一般情况下最多不能超过30个字段(可将大字段和不常用的字段拆分到新表中)
  172. 建表Demo:
  173. <pre>
  174. CREATE TABLE `user_base` (
  175. `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '用户 ID' ,
  176. `username` char(50) NOT NULL DEFAULT ' ' COMMENT '用户名' ,
  177. `password` char(32) NOT NULL DEFAULT ' ' COMMENT '密码' ,
  178. `email` char(50) NOT NULL DEFAULT ' ' COMMENT '电子邮件' ,
  179. `regdate` int(10) UNSIGNED NOT NULL DEFAULT 0 COMMENT '注册日期' ,
  180. `last_login_ip` int(11) NOT NULL DEFAULT 0 COMMENT '最后登录IP' ,
  181. `status` tinyint(1) UNSIGNED NOT NULL DEFAULT 0 COMMENT '状态:1正常;2已删除;' ,
  182. PRIMARY KEY (`id`),
  183. UNIQUE INDEX `uniq_username` (`username`) USING BTREE
  184. )
  185. ENGINE=MyISAM
  186. DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
  187. COMMENT='用户基本表'
  188. AUTO_INCREMENT=1
  189. </pre>
  190. </pre>",
  191. ),
  192. );
  193. if (!isset($data[$this->db])) {
  194. Dever::alert('没有该数据项');
  195. }
  196. $this->data['data'] = $data[$this->db];
  197. return $this->data['data'];
  198. }
  199. return array();
  200. }
  201. private function load_api()
  202. {
  203. $data = Dever::load('manage/api-getAll');
  204. if (isset($data['manage'])) {
  205. unset($data['manage']);
  206. }
  207. $keys = array_keys($data);
  208. $list = array();
  209. $project = Dever::load('manage/project.get');
  210. foreach ($keys as $k => $v) {
  211. if (isset($project[$v])) {
  212. $list[$v] = $project[$v];
  213. }
  214. }
  215. $this->create_nav($list, -1000);
  216. if (isset($this->data['nav'][$this->db]) && isset($data[$this->db])) {
  217. $this->doc = '介绍' . $this->data['nav'][$this->db]['name'] . '项目下的对外接口';
  218. $config = Dever::db('manage/api')->config;
  219. $type = $config['gettype'];
  220. $doc = $config['doc'];
  221. $html = $config['html'];
  222. $this->data['data'] = array();
  223. $this->data['data']['api']['name'] = '公共参数说明';
  224. $this->data['data']['api']['content'] = '<pre>加密共有两种方式:<br />1、请求加密:所有传输参数均要进行加密,通过token加密,加密方法如下:<br />' . $doc . '<br /><br />2、登录加密:由服务端生成signature,然后客户端保存此signature,每次客户端向服务端请求,均需要传输signature,本方式适用移动端登录状态。signature中自带uid。</pre>';
  225. $this->data['data']['api']['content'] .= $html;
  226. $this->class = Dever::load('manage/api');
  227. $url = Dever::url('manage/api.update_col');
  228. foreach ($data[$this->db] as $k => $v) {
  229. $one = array
  230. (
  231. 'option_api_id' => $v['id'],
  232. 'option_parent_id' => -1,
  233. );
  234. $requestData = Dever::db('manage/api_request')->all($one);
  235. $responseData = Dever::db('manage/api_response')->all($one);
  236. $request = $this->class->showTable($requestData, $url, 'api_request');
  237. $response = $this->class->showTable($responseData, $url, 'api_response');
  238. $this->data['data'][$k]['content'] = '<h3>接口类型:</h3>';
  239. $this->data['data'][$k]['content'] .= '<pre>' . ($v['type'] == 1 ? 'get' : 'post') . '</pre>';
  240. $this->data['data'][$k]['content'] .= '<h3>接口地址:</h3>';
  241. $this->data['data'][$k]['content'] .= '<pre>' . Dever::url($v['site'], $v['project']) . '</pre>';
  242. $this->data['data'][$k]['content'] .= '<h3>请求参数:</h3>';
  243. $this->data['data'][$k]['content'] .= (strip_tags($request) ? $request : '空');
  244. //$this->data['data'][$k]['content'] .= $this->loadApiData($url, 'request', $requestData));
  245. $this->data['data'][$k]['content'] .= '<h3>返回参数:</h3>';
  246. $this->data['data'][$k]['content'] .= $response;
  247. $this->data['data'][$k]['content'] .= $this->loadApiData($url, 'response', $responseData);
  248. $v['name'] = '<span class="edit" data-col="name" data-url="'.$url.'" data-id="'.$v['id'].'" data-type="api" >' . $v['name'] . '</span>';
  249. $this->data['data'][$k]['name'] = $v['name'];
  250. }
  251. return $this->data['data'];
  252. }
  253. return array();
  254. }
  255. private function loadApiData($url, $key, $data, $num = 3, $name = '')
  256. {
  257. $num = $num-1;
  258. return $this->loadApiDataOne($key, $url, $data, $num, $name);
  259. }
  260. private function loadApiDataOne($key, $url, $data, $num, $name = '')
  261. {
  262. $result = '';
  263. foreach ($data as $k => $v) {
  264. if (strpos($v['desc'], 'array') !== false) {
  265. $one = array
  266. (
  267. 'option_parent_id' => $v['id'],
  268. );
  269. $all = Dever::db('manage/api_' . $key)->all($one);
  270. if ($all) {
  271. $table = $this->class->showTable($all, $url, 'api_' . $key);
  272. if ($name) {
  273. $name .= '.';
  274. $name = str_replace('..', '.', $name);
  275. }
  276. $result .= '<h3>'. $name . $v['name'].':</h3>';
  277. $result .= $table;
  278. if ($num > 0) {
  279. $result .= $this->loadApiData($url, $key, $all, $num, $name . $v['name']);
  280. }
  281. }
  282. }
  283. }
  284. return $result;
  285. }
  286. }