-
Notifications
You must be signed in to change notification settings - Fork 130
/
index.php
80 lines (64 loc) · 2.13 KB
/
index.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?php
// vim: set et sw=4 ts=4 sts=4 ft=php fdm=marker ff=unix fenc=utf8 nobomb:
/**
* PHP Readability
*
* @author mingcheng<i.feelinglucky#gmail.com>
* @date 2011-02-17
* @link http://www.gracecode.com/
*/
require 'config.inc.php';
require 'common.inc.php';
require 'lib/Readability.inc.php';
$request_url = getRequestParam("url", "");
$output_type = strtolower(getRequestParam("type", "html"));
// 如果 URL 参数不正确,则跳转到首页
if (!preg_match('/^http:\/\//i', $request_url) ||
!filter_var($request_url, FILTER_VALIDATE_URL, FILTER_FLAG_SCHEME_REQUIRED)) {
include 'template/index.html';
exit;
}
$request_url_hash = md5($request_url);
$request_url_cache_file = sprintf(DIR_CACHE."/%s.url", $request_url_hash);
// 缓存请求数据,避免重复请求
if (file_exists($request_url_cache_file) &&
(time() - filemtime($request_url_cache_file) < CACHE_TIME)) {
$source = file_get_contents($request_url_cache_file);
} else {
$handle = curl_init();
curl_setopt_array($handle, array(
CURLOPT_USERAGENT => USER_AGENT,
CURLOPT_FOLLOWLOCATION => true,
CURLOPT_HEADER => false,
CURLOPT_HTTPGET => true,
CURLOPT_RETURNTRANSFER => true,
CURLOPT_TIMEOUT => 30,
CURLOPT_URL => $request_url
));
$source = curl_exec($handle);
curl_close($handle);
// Write request data into cache file.
@file_put_contents($request_url_cache_file, $source);
}
// 判断编码
//if (!$charset = mb_detect_encoding($source)) {
//}
preg_match("/charset=([\w|\-]+);?/", $source, $match);
$charset = isset($match[1]) ? $match[1] : 'utf-8';
/**
* 获取 HTML 内容后,解析主体内容
*/
$Readability = new Readability($source, $charset);
$Data = $Readability->getContent();
switch($output_type) {
case 'json':
header("Content-type: text/json;charset=utf-8");
$Data['url'] = $request_url;
echo json_encode($Data);
break;
case 'html': default:
header("Content-type: text/html;charset=utf-8");
$title = $Data['title'];
$content = $Data['content'];
include 'template/reader.html';
}