Files
WechatMomentScreenshot/cfworker_proxy.js

80 lines
2.7 KiB
JavaScript
Raw Normal View History

2023-06-13 18:44:12 +08:00
addEventListener('fetch', event => event.respondWith(handleRequest(event.request)));
/**
* Respond to the request
* @param {Request} request
*/
async function handleRequest(request) {
const result = {
success: false,
title: '',
cover: '',
2023-06-13 18:44:12 +08:00
author: '',
};
2023-06-13 18:44:12 +08:00
const origin = request.headers.get('origin') || '';
const responseConfig = {
status: 200,
headers: {
'Content-Type': 'application/json',
},
}
2023-06-13 18:44:12 +08:00
if (origin && (origin.startsWith('https://') || origin.startsWith('http://'))) {
responseConfig.headers['Access-Control-Allow-Origin'] = origin;
}
const articleURL = new URL(request.url).searchParams.get('url');
try {
if (!articleURL || !articleURL.startsWith('https://mp.weixin.qq.com')) throw new Error('Invalid URL');
2023-06-13 18:44:12 +08:00
const articleContent = await fetch(articleURL).then(r => r.text());
2023-06-13 18:44:12 +08:00
let match = articleContent.match(
/var nickname = "(?<author>[\S\s]*?)";[\S\s]*?var msg_title = \'(?<title>[\S\s]*?)\'.html\(false\);[\S\s]*?var msg_cdn_url = "(?<cover>[\S\s]*?)";/
);
2023-06-13 18:44:12 +08:00
if (!match) {
// Test case:
// https://mp.weixin.qq.com/s/_F1sw9yrzMfpARzvHaG_MA
// https://mp.weixin.qq.com/s/HpfdeLrEkXwlEzSP2yzN1A
match = articleContent.match(
/d\.title = xml \? getXmlValue\('title\.DATA'\) : '(?<title>.*?)';[\S\s]*?d\.nick_name = xml \? getXmlValue\('nick_name\.DATA'\) : '(?<author>.*?)';[\S\s]*?d\.cdn_1_1_img = xml \? getXmlValue\('cdn_url_1_1\.DATA'\) : '(?<cover>.*?)';/
);
}
if (!match) throw new Error('Unable to match content');
result.title = match.groups.title;
2023-06-13 18:44:12 +08:00
result.author = match.groups.author;
for (const [k, v] of Object.entries({
'&#96;': '`',
'&#39;': '\'',
'&quot;': '"',
'&nbsp;': ' ',
'&gt;': '>',
'&lt;': '<',
'&yen;': '¥',
2023-02-13 14:48:42 +08:00
'&amp;': '&',
2023-06-13 18:44:12 +08:00
})) {
result.title = result.title.replace(new RegExp(k, 'g'), v);
result.author = result.author.replace(new RegExp(k, 'g'), v);
}
2023-06-13 18:44:12 +08:00
const u = new URL('https://images.weserv.nl/');
for (const [k, v] of Object.entries({
url: match.groups.cover,
il: '',
we: '',
h: 360,
q: 70,
2023-06-13 18:44:12 +08:00
encoding: 'base64',
})) u.searchParams.set(k, v.toString());
result.cover = await fetch(u.toString()).then(r => r.text());
result.success = true;
2023-06-13 18:44:12 +08:00
console.log(articleURL);
} catch (error) {
console.log(error);
}
2021-05-29 00:04:35 +08:00
return new Response(JSON.stringify(result), responseConfig);
}