加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
WebCopyer.go 14.59 KB
一键复制 编辑 原始数据 按行查看 历史
xiaostar 提交于 2013-06-19 20:19 . make it configable
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561
package main
import (
"fmt"
"io"
"io/ioutil"
"net/http"
"os"
"path/filepath"
"regexp"
"strings"
"strconv"
"log"
"time"
"flag"
)
/*
var url = "http://ieqi.net/wp-content/themes/ieqi-wptheme/css/main.css"
var destDir = "F:\\kuaipan\\Projects\\webcopyer\\template"
var img_ext = []string{".jpg", ".gif", ".png", ".jpeg", ".JPG", ".GIF", ".PNG", ".JPEG", ".ico", ".ICO"}
var css_ext = []string{".css", ".less", ".CSS", ".LESS"}
var js_ext = []string{".js", ".JS"}
var other_ext = []string{".dll"}
var extArray = []string{".jpg", ".gif", ".png", ".jpeg", ".css", ".less", ".js", ".ico", ".JPG", ".GIF", ".PNG", ".JPEG", ".CSS", ".LESS", ".JS", ".ICO", ".dll"}
var css_resource_list []string
*/
type Config map[string]string
var(
cfg Config
current_url string
destDir string
css_resource_list []string
img_ext []string
css_ext []string
js_ext []string
other_ext []string
html_dir string
img_dir string
css_dir string
js_dir string
other_dir string
extArray []string
configFile = *flag.String("config", "config", "配置文件路径")
method string
arg1 string
arg2 string
)
func init() {
flag.Parse()
method = flag.Arg(0)
arg1 = flag.Arg(1)
arg2 = flag.Arg(2)
//或取配置文件
cfg := Configure(configFile)
destDir = cfg.getStr("destDir")
img_ext = cfg.getArray("img_ext")
css_ext = cfg.getArray("css_ext")
js_ext = cfg.getArray("js_ext")
other_ext = cfg.getArray("other_ext")
html_dir = fixResPath(cfg.getStr("html_dir"))
img_dir = fixResPath(cfg.getStr("img_dir"))
css_dir = fixResPath(cfg.getStr("css_dir"))
js_dir = fixResPath(cfg.getStr("js_dir"))
other_dir = fixResPath(cfg.getStr("other_dir"))
extArray = arrayMerge(extArray,img_ext)
extArray = arrayMerge(extArray,css_ext)
extArray = arrayMerge(extArray,js_ext)
extArray = arrayMerge(extArray,other_ext)
destDir = checkAndMkDir(destDir)
}
func main() {
// fmt.Println(getDestDirAndFiletype("http://www.chinaz.com/"))
//getAll("http://drizzlep.diandian.com/", "") //获取在线模版
//getAll("F:\\kuaipan\\Projects\\webcopyer\\template\\index.html", "http://drizzlep.diandian.com/page/2/") //获取本地模版
//完整测试
// getHtml("http://www.chinaz.com/")
//测试download
// down_resource("https://ss.cnnic.cn/seallogo.dll?sn=e12020335020010628301467&size=3")
//css测试 常用
// getCss("http://img.chinaz.com/templates/chinaz/css/style.css?v=20121121")
//css测试 import
//getCss("http://download.csdn.net/css/download.css")
//fix_url 测试
// current_url = "http://ieqi.net/"
// fmt.Println(fix_url("./sdfs/sdfa/wahaha.jpg"))
if method == "get" {
getAll(arg1, "") //获取在线模版
}else if method == "getLocal"{
getAll(arg1, arg2) //获取本地模版
}else if method == "getCss" {
getCss(arg1)
}else{
getAll(method, "") //获取在线模版
}
}
func getAll(file string, url string) {
var html string
if strings.HasPrefix(file, "http") || strings.HasPrefix(file, "https") {
html = http_get(file)
current_url = file
} else {
htmlbyte, _ := ioutil.ReadFile(file)
html = string(htmlbyte)
current_url = url
}
html = extruct_html_resource(html)
ioutil.WriteFile(destDir + html_dir + get_true_filename(current_url), []byte(html), 0777) //转储html
// fmt.Println(css_resource_list)
for k := range css_resource_list {
current_url = fix_url(css_resource_list[k])
//getCss(current_url)
css := http_get(current_url)
css = extruct_css_resource(css) //1、改引用路径 2、下载资源
dest := getDestDir("css")
write_erro := ioutil.WriteFile(destDir + dest + get_true_filename(current_url), []byte(css), 0777) //转储css
if write_erro != nil {
fmt.Println(write_erro)
}
}
}
func getHtml(url string) {
html := http_get(url)
current_url = url
html = extruct_html_resource(html)
ioutil.WriteFile(destDir + html_dir + get_true_filename(url), []byte(html), 0777) //转储css
}
func getCss(url string) {
css := http_get(url)
current_url = url
css = extruct_css_resource(css) //1、改引用路径 2、下载资源
dest := getDestDir("css")
ioutil.WriteFile(destDir + dest + get_true_filename(url), []byte(css), 0777) //转储css
}
//==============================================
//css提取
func extruct_css_resource(content string) string {
re1, _ := regexp.Compile("background(-image)?\\s*:[^;})]*url\\s*\\((\\S+)?\\)") //src\s*=\s*(["|'])([\S\s]+?)\1
content = re1.ReplaceAllStringFunc(content, css_change_path_1)
re2, _ := regexp.Compile("@import.*url\\s*(\\(.*\\));") //src\s*=\s*(["|'])([\S\s]+?)\1
content = re2.ReplaceAllStringFunc(content, append_import_css_resource)
return content
}
func css_change_path_1(str string) string {
re, _ := regexp.Compile("background(-image)?\\s*:[^;})]*url\\s*\\((\\S+)?\\)")
old_path := re.FindStringSubmatch(str)[2]
old_path = strings.Trim(old_path, "\"' ")
new_path := css_change_path(str, old_path)
return new_path
}
func append_import_css_resource(str string) string {
re, _ := regexp.Compile("@import.*url\\s*\\((.*)\\);")
import_url := re.FindStringSubmatch(str)[1]
import_url = fix_url(strings.Trim(import_url, "\"' "))
getCss(import_url)
return str
}
//@import.*url\s*(\(.*\));
func css_change_path(str string, old_path string) string {
dir, filetype := getDestDirAndFiletype(old_path)
if dir != "unexcept" {
down_resource(old_path, dir)
true_filename := get_true_filename(old_path)
relPath := getRelPath(css_dir , getDestDir(filetype) )
return strings.Replace(str, old_path, relPath + "/" + true_filename, -1)
}
return str
}
//================================================
//htmlt资源提取
func extruct_html_resource(content string) string {
re1, _ := regexp.Compile("src\\s*=\\s*\"([\\S\\s]+?)\"")
re2, _ := regexp.Compile("src\\s*=\\s*'([\\S\\s]+?)'") //src\s*=\s*(["|'])([\S\s]+?)\1
re3, _ := regexp.Compile("<\\s*link([\\S\\s]+?)href\\s*=\\s*\"([\\S\\s]+?)\"") //src\s*=\s*(["|'])([\S\s]+?)\1
re4, _ := regexp.Compile("<\\s*link([\\S\\s]+?)href\\s*=\\s*'([\\S\\s]+?)'") //src\s*=\s*(["|'])([\S\s]+?)\1
re5, _ := regexp.Compile("background(-image)?\\s*:[^;})]*url\\s*\\((\\S+)?\\)") //src\s*=\s*(["|'])([\S\s]+?)\1
content = re1.ReplaceAllStringFunc(content, html_change_path_1)
content = re2.ReplaceAllStringFunc(content, html_change_path_2)
content = re3.ReplaceAllStringFunc(content, html_change_path_3)
content = re4.ReplaceAllStringFunc(content, html_change_path_4)
content = re5.ReplaceAllStringFunc(content, html_css_change_path)
return content
}
func html_change_path_1(str string) string {
re, _ := regexp.Compile("src\\s*=\\s*\"([\\S\\s]+?)\"")
old_path := re.FindStringSubmatch(str)[1]
new_path := html_change_path(str, old_path)
return new_path
}
func html_change_path_2(str string) string {
re, _ := regexp.Compile("src\\s*=\\s*'([\\S\\s]+?)'")
old_path := re.FindStringSubmatch(str)[1]
new_path := html_change_path(str, old_path)
return new_path
}
func html_change_path_3(str string) string {
re, _ := regexp.Compile("<\\s*link([\\S\\s]+?)href\\s*=\\s*\"([\\S\\s]+?)\"")
old_path := re.FindStringSubmatch(str)[2]
new_path := html_change_path(str, old_path)
return new_path
}
func html_change_path_4(str string) string {
re, _ := regexp.Compile("<\\s*link([\\S\\s]+?)href\\s*=\\s*'([\\S\\s]+?)'")
old_path := re.FindStringSubmatch(str)[2]
new_path := html_change_path(str, old_path)
return new_path
}
func html_change_path(str string, old_path string) string {
dir, filetype := getDestDirAndFiletype(old_path)
if dir != "unexcept" {
down_resource(old_path, dir)
if filetype == "css" {
css_resource_list = append(css_resource_list, old_path)
}
true_filename := get_true_filename(old_path)
resDir := getDestDir(filetype)
relPath := getRelPath(html_dir,resDir)
return strings.Replace(str, old_path, relPath + "/" + true_filename, -1)
}
return str
}
func html_css_change_path(str string) string {
re, _ := regexp.Compile("background(-image)?\\s*:[^;})]*url\\s*\\((\\S+)?\\)")
old_path := re.FindStringSubmatch(str)[2]
old_path = strings.Trim(old_path, "\"' ")
new_path := _html_css_change_path(str, old_path)
return new_path
}
func _html_css_change_path(str string, old_path string) string {
dir, filetype := getDestDirAndFiletype(old_path)
if dir != "unexcept" {
down_resource(old_path, dir)
true_filename := get_true_filename(old_path)
resDir := getDestDir(filetype)
relPath := getRelPath(html_dir,resDir)
return strings.Replace(str, old_path, relPath + "/" + true_filename, -1)
}
return str
}
//======================================
func http_get(url string) string {
res, err := http.Get(url)
if err != nil {
fmt.Println(err)
os.Exit(0)
}
defer res.Body.Close()
body, _ := ioutil.ReadAll(res.Body)
return string(body)
}
func get_true_filename(url string) string {
filename := filepath.Base(url)
extname := filepath.Ext(url)
for k := range extArray {
if strings.Contains(extname, extArray[k]) {
true_filename := strings.Replace(filename, extname, extArray[k], -1)
return true_filename
}
}
true_filename := strings.Split(filename, "?")[0]
if len(true_filename) > 0 {
fmt.Println("未知类型文件:" + url)
return true_filename
}
return filename
}
func getDestDirAndFiletype(url string) (string, string) {
filetype := ""
dir := destDir
if in_array(filepath.Ext(url), img_ext) {
filetype = "images"
} else if in_array(filepath.Ext(url), css_ext) {
filetype = "css"
} else if in_array(filepath.Ext(url), js_ext) {
filetype = "js"
} else if in_array(filepath.Ext(url), other_ext) {
filetype = "other"
} else {
return "unexcept", "unexcept"
}
dir = dir + "\\theme\\" + filetype + "\\"
return dir, filetype
}
func down_resource(url string, destDir string) {
filename := get_true_filename(url)
fullfilename := destDir + filename
fmt.Println(url)
fixed_url := fix_url(url) //矫正url(相对路径转换为绝对路径)
fmt.Println(fullfilename)
fmt.Println(fixed_url)
if strings.HasPrefix(fixed_url, "http") || strings.HasPrefix(fixed_url, "https") {
resp, err := http.Get(fixed_url)
// resp, err := http.Get("http://a.36krcnd.com/photo/9b6493956db5cc890654a6b21bb2d77e.gif")
if err != nil {
fmt.Println(err)
os.Exit(0)
}
out, create_err := os.Create(fullfilename)
if create_err != nil {
fmt.Println(create_err)
os.Exit(0)
}
// out, _ := os.Create("F:\\kuaipan\\templateCopyer\\template\\images\\9b6493956db5cc890654a6b21bb2d77e.gif")
defer out.Close()
defer resp.Body.Close()
_, copy_err := io.Copy(out, resp.Body)
if copy_err != nil {
fmt.Println(copy_err)
os.Exit(0)
}
out.Close()
//return filetype + "/" + filename
}
}
func in_array(v string, array []string) bool {
for k := range array {
if strings.Contains(strings.ToLower(v), strings.ToLower(array[k])) {
return true
}
}
return false
}
//http://www.baidu.com/wahaha/sdfds/index.html
func fix_url(url string) string {
re1, _ := regexp.Compile("http[s]?://[^/]+")
destrooturl := re1.FindString(current_url)
//当url为:/wahaha/xiaoxixi/tupian.png
if strings.HasPrefix(url, "/") {
// re1,_ := regexp.Compile("http[s]?://[^/]+")
// destrooturl := re1.FindString(current_url)
url = destrooturl + url
}
//当url为:"../wahaha/xiaoxixi/tupian.png"、"./wahaha/xiaoxixi/tupian.png"、"wahaha/xiaoxixi/tupian.png"
if !strings.HasPrefix(url, "/") && !strings.HasPrefix(url, "http") && !strings.HasPrefix(url, "https") {
// current_url = strings.TrimSuffix(current_url, "/")
if destrooturl == current_url {
url = current_url + "/" + url
} else {
re2, _ := regexp.Compile("[^/]+?$")
url = re2.ReplaceAllString(current_url, "") + url
}
}
return url
}
func Configure(filePath string) Config {
configByte, err := ioutil.ReadFile(filePath)
if err != nil {
log.Fatal("配置文件不存在!")
}
configMap := Config{}
config := strings.Replace("\r\n", "\n", string(configByte), -1)
configArray := strings.Split(config, "\n")
for _, v := range configArray {
v = Trim(v)
vArray := strings.SplitN(v, ":", 2)
if len(vArray) == 2 && !strings.HasPrefix(v, "#") {
key := Trim(vArray[0])
value := Trim(vArray[1])
configMap[key] = value
}
}
return configMap
}
func (cfg Config)getInt(key string) int{
value, err := strconv.Atoi(cfg[key])
if err != nil {
log.Fatal(key + "值未填写或填写不正确,请确认为整数")
}
return value
}
func (cfg Config)getStr(key string) string{
if cfg[key] == "" {
log.Fatal(key + "值未填写或填写不正确")
}
return cfg[key]
}
func (cfg Config)getArray(key string) []string{
return strings.Split(cfg[key], "|")
}
func Trim(s string) string {
return strings.Trim(s, " \t\n\r")
}
// 检查文件或目录是否存在
// 如果由 filename 指定的文件或目录存在则返回 true,否则返回 false
func exist(filename string) bool {
_, err := os.Stat(filename)
return err == nil || os.IsExist(err)
}
func arrayMerge(old []string, other []string) []string{
for _,v := range other {
old = append(old,v)
}
return old
}
func checkAndMkDir(destDir string) string{
//判断destDir是否存在 不存在的话创建 失败的话报错终止
if !exist(destDir) {
err := os.Mkdir(destDir, os.ModePerm)
if err != nil {
log.Fatal("无法创建目录!")
}
}
destDir = destDir + "\\" + strconv.Itoa(int(time.Now().Unix()))
if !exist(destDir) {
err := os.Mkdir(destDir, os.ModePerm)
if err != nil {
log.Fatal("无法创建目录!")
}
}
if !exist(destDir+"\\theme\\js") {
err := os.MkdirAll(destDir+"\\theme\\js", os.ModePerm)
if err != nil {
log.Fatal("无法创建目录!")
}
}
if !exist(destDir+"\\theme\\images") {
err := os.MkdirAll(destDir+"\\theme\\images", os.ModePerm)
if err != nil {
log.Fatal("无法创建目录!")
}
}
if !exist(destDir+"\\theme\\css") {
err := os.MkdirAll(destDir+"\\theme\\css", os.ModePerm)
if err != nil {
log.Fatal("无法创建目录!")
}
}
return destDir
}
func getDestDir(filetype string) string{
path := ""
if filetype == "images" {
path = img_dir
}else if filetype == "js" {
path = js_dir
}else if filetype == "css" {
path = css_dir
}else if filetype == "other" {
path = other_dir
}else if filetype == "html" {
path = html_dir
}
return path
}
//检查修复各个资源存储路径
func fixResPath(path string) string{
fixed := path
if path == "" || path == "\\"{
fixed = "\\"
}else{
if !strings.HasSuffix(path,"\\") {
fixed = fixed + "\\"
}
}
if !strings.HasPrefix(path,"\\") {
fixed = "\\" + path
}
return fixed
}
func getRelPath(base string,target string) string{
rel, _ := filepath.Rel(base , target )
rel = strings.Replace(rel,"/\\","/",-1)
rel = strings.Replace(rel,"\\","/",-1)
return rel
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化