From d173755f98b73607f200012fff658b7f37122b91 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E8=80=97=E5=AD=90?= Date: Fri, 23 Jan 2026 21:57:05 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E4=BC=AA=E9=9D=99=E6=80=81=E9=85=8D?= =?UTF-8?q?=E7=BD=AE=E6=9C=AC=E5=9C=B0=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- internal/biz/cache.go | 2 - internal/data/cache.go | 14 ------- internal/data/website.go | 21 ++++++----- internal/job/panel_task.go | 10 ----- internal/service/cli.go | 3 -- pkg/api/api_test.go | 5 --- pkg/api/rewrite.go | 33 ----------------- pkg/embed/embed.go | 3 ++ pkg/embed/rewrites/nginx/crmeb.conf | 6 +++ pkg/embed/rewrites/nginx/dabr.conf | 5 +++ pkg/embed/rewrites/nginx/dbshop.conf | 3 ++ pkg/embed/rewrites/nginx/dedecms.conf | 10 +++++ pkg/embed/rewrites/nginx/discuz.conf | 7 ++++ pkg/embed/rewrites/nginx/discuzq.conf | 3 ++ pkg/embed/rewrites/nginx/discuzx.conf | 14 +++++++ pkg/embed/rewrites/nginx/drupal.conf | 3 ++ pkg/embed/rewrites/nginx/ecshop.conf | 37 +++++++++++++++++++ pkg/embed/rewrites/nginx/edusoho.conf | 8 ++++ pkg/embed/rewrites/nginx/emlog.conf | 3 ++ pkg/embed/rewrites/nginx/empirecms.conf | 8 ++++ pkg/embed/rewrites/nginx/laravel.conf | 3 ++ pkg/embed/rewrites/nginx/maccms.conf | 5 +++ pkg/embed/rewrites/nginx/niushop.conf | 6 +++ pkg/embed/rewrites/nginx/pbootcms.conf | 6 +++ pkg/embed/rewrites/nginx/phpcms.conf | 9 +++++ pkg/embed/rewrites/nginx/phpwind.conf | 4 ++ pkg/embed/rewrites/nginx/sablog.conf | 16 ++++++++ pkg/embed/rewrites/nginx/seacms.conf | 11 ++++++ pkg/embed/rewrites/nginx/shopex.conf | 5 +++ pkg/embed/rewrites/nginx/shopwind.conf | 14 +++++++ pkg/embed/rewrites/nginx/thinkphp.conf | 8 ++++ pkg/embed/rewrites/nginx/typecho.conf | 3 ++ .../rewrites/nginx/wordpress-multisite.conf | 9 +++++ pkg/embed/rewrites/nginx/wordpress.conf | 5 +++ pkg/embed/rewrites/nginx/zblog.conf | 9 +++++ 35 files changed, 235 insertions(+), 76 deletions(-) delete mode 100644 pkg/api/rewrite.go create mode 100644 pkg/embed/rewrites/nginx/crmeb.conf create mode 100644 pkg/embed/rewrites/nginx/dabr.conf create mode 100644 pkg/embed/rewrites/nginx/dbshop.conf create mode 100644 pkg/embed/rewrites/nginx/dedecms.conf create mode 100644 pkg/embed/rewrites/nginx/discuz.conf create mode 100644 pkg/embed/rewrites/nginx/discuzq.conf create mode 100644 pkg/embed/rewrites/nginx/discuzx.conf create mode 100644 pkg/embed/rewrites/nginx/drupal.conf create mode 100644 pkg/embed/rewrites/nginx/ecshop.conf create mode 100644 pkg/embed/rewrites/nginx/edusoho.conf create mode 100644 pkg/embed/rewrites/nginx/emlog.conf create mode 100644 pkg/embed/rewrites/nginx/empirecms.conf create mode 100644 pkg/embed/rewrites/nginx/laravel.conf create mode 100644 pkg/embed/rewrites/nginx/maccms.conf create mode 100644 pkg/embed/rewrites/nginx/niushop.conf create mode 100644 pkg/embed/rewrites/nginx/pbootcms.conf create mode 100644 pkg/embed/rewrites/nginx/phpcms.conf create mode 100644 pkg/embed/rewrites/nginx/phpwind.conf create mode 100644 pkg/embed/rewrites/nginx/sablog.conf create mode 100644 pkg/embed/rewrites/nginx/seacms.conf create mode 100644 pkg/embed/rewrites/nginx/shopex.conf create mode 100644 pkg/embed/rewrites/nginx/shopwind.conf create mode 100644 pkg/embed/rewrites/nginx/thinkphp.conf create mode 100644 pkg/embed/rewrites/nginx/typecho.conf create mode 100644 pkg/embed/rewrites/nginx/wordpress-multisite.conf create mode 100644 pkg/embed/rewrites/nginx/wordpress.conf create mode 100644 pkg/embed/rewrites/nginx/zblog.conf diff --git a/internal/biz/cache.go b/internal/biz/cache.go index 98b205ff..d9248bad 100644 --- a/internal/biz/cache.go +++ b/internal/biz/cache.go @@ -9,7 +9,6 @@ const ( CacheKeyApps CacheKey = "apps" CacheKeyEnvironment CacheKey = "environment" CacheKeyTemplates CacheKey = "templates" - CacheKeyRewrites CacheKey = "rewrites" ) type Cache struct { @@ -26,5 +25,4 @@ type CacheRepo interface { UpdateApps() error UpdateEnvironments() error UpdateTemplates() error - UpdateRewrites() error } diff --git a/internal/data/cache.go b/internal/data/cache.go index cc630752..18f78c8d 100644 --- a/internal/data/cache.go +++ b/internal/data/cache.go @@ -110,17 +110,3 @@ func (r *cacheRepo) UpdateTemplates() error { return r.Set(biz.CacheKeyTemplates, string(encoded)) } - -func (r *cacheRepo) UpdateRewrites() error { - rewrites, err := r.api.RewritesByType("nginx") - if err != nil { - return err - } - - encoded, err := json.Marshal(rewrites) - if err != nil { - return err - } - - return r.Set(biz.CacheKeyRewrites, string(encoded)) -} diff --git a/internal/data/website.go b/internal/data/website.go index 9e1aeb42..daa8b8cc 100644 --- a/internal/data/website.go +++ b/internal/data/website.go @@ -3,7 +3,6 @@ package data import ( "bufio" "context" - "encoding/json" "errors" "fmt" "log/slog" @@ -23,7 +22,6 @@ import ( "github.com/acepanel/panel/internal/biz" "github.com/acepanel/panel/internal/http/request" "github.com/acepanel/panel/pkg/acme" - "github.com/acepanel/panel/pkg/api" "github.com/acepanel/panel/pkg/cert" "github.com/acepanel/panel/pkg/embed" "github.com/acepanel/panel/pkg/io" @@ -64,19 +62,24 @@ func NewWebsiteRepo(t *gotext.Locale, db *gorm.DB, log *slog.Logger, cache biz.C } func (r *websiteRepo) GetRewrites() (map[string]string, error) { - cached, err := r.cache.Get(biz.CacheKeyRewrites) + webServer, err := r.setting.Get(biz.SettingKeyWebserver) if err != nil { - return nil, err + return make(map[string]string), err } - var rewrites api.Rewrites - if err = json.Unmarshal([]byte(cached), &rewrites); err != nil { - return nil, err + entries, err := embed.RewritesFS.ReadDir(webServer) + if err != nil { + return make(map[string]string), err } rw := make(map[string]string) - for rewrite := range slices.Values(rewrites) { - rw[rewrite.Name] = rewrite.Content + for _, entry := range entries { + if entry.IsDir() { + continue + } + if content, err := embed.RewritesFS.ReadFile(filepath.Join(webServer, entry.Name())); err == nil { + rw[strings.TrimSuffix(entry.Name(), filepath.Ext(entry.Name()))] = string(content) + } } return rw, nil diff --git a/internal/job/panel_task.go b/internal/job/panel_task.go index 702510da..8ebf86f5 100644 --- a/internal/job/panel_task.go +++ b/internal/job/panel_task.go @@ -77,7 +77,6 @@ func (r *PanelTask) Run() { if offline, err := r.settingRepo.GetBool(biz.SettingKeyOfflineMode); err == nil && !offline { r.updateCategories() r.updateApps() - r.updateRewrites() if autoUpdate, err := r.settingRepo.GetBool(biz.SettingKeyAutoUpdate); err == nil && autoUpdate { r.updatePanel() } @@ -108,15 +107,6 @@ func (r *PanelTask) updateApps() { }) } -// 更新伪静态缓存 -func (r *PanelTask) updateRewrites() { - time.AfterFunc(time.Duration(rand.IntN(300))*time.Second, func() { - if err := r.cacheRepo.UpdateRewrites(); err != nil { - r.log.Warn("failed to update rewrites cache", slog.String("type", biz.OperationTypePanel), slog.Uint64("operator_id", 0), slog.Any("err", err)) - } - }) -} - // 更新面板 func (r *PanelTask) updatePanel() { if r.taskRepo.HasRunningTask() { diff --git a/internal/service/cli.go b/internal/service/cli.go index f43f65d3..4b2e2eb1 100644 --- a/internal/service/cli.go +++ b/internal/service/cli.go @@ -130,9 +130,6 @@ func (s *CliService) Sync(ctx context.Context, cmd *cli.Command) error { if err := s.cacheRepo.UpdateTemplates(); err != nil { return errors.New(s.t.Get("Failed to synchronize app data: %v", err)) } - if err := s.cacheRepo.UpdateRewrites(); err != nil { - return errors.New(s.t.Get("Failed to synchronize rewrite rules: %v", err)) - } fmt.Println(s.t.Get("Data synchronized successfully")) return nil diff --git a/pkg/api/api_test.go b/pkg/api/api_test.go index 7a777ceb..5c5f45c9 100644 --- a/pkg/api/api_test.go +++ b/pkg/api/api_test.go @@ -61,8 +61,3 @@ func (s *APITestSuite) TestTemplateCallback() { err := s.api.TemplateCallback("nginx") s.NoError(err) } - -func (s *APITestSuite) TestGetRewritesByType() { - _, err := s.api.RewritesByType("nginx") - s.NoError(err) -} diff --git a/pkg/api/rewrite.go b/pkg/api/rewrite.go deleted file mode 100644 index b5c30115..00000000 --- a/pkg/api/rewrite.go +++ /dev/null @@ -1,33 +0,0 @@ -package api - -import ( - "fmt" - "time" -) - -type Rewrite struct { - CreatedAt time.Time `json:"created_at"` - UpdatedAt time.Time `json:"updated_at"` - Name string `json:"name"` - Type string `json:"type"` - Content string `json:"content"` -} - -type Rewrites []Rewrite - -func (r *API) RewritesByType(typ string) (*Rewrites, error) { - resp, err := r.client.R().SetResult(&Response{}).Get(fmt.Sprintf("/rewrites/%s", typ)) - if err != nil { - return nil, err - } - if !resp.IsSuccess() { - return nil, fmt.Errorf("failed to get rewrites: %s", resp.String()) - } - - rewrites, err := getResponseData[Rewrites](resp) - if err != nil { - return nil, err - } - - return rewrites, nil -} diff --git a/pkg/embed/embed.go b/pkg/embed/embed.go index e8fb0a38..3d645746 100644 --- a/pkg/embed/embed.go +++ b/pkg/embed/embed.go @@ -11,5 +11,8 @@ var WebsiteFS embed.FS //go:embed all:locales/* var LocalesFS embed.FS +//go:embed all:rewrites/* +var RewritesFS embed.FS + //go:embed all:error/* var ErrorFS embed.FS diff --git a/pkg/embed/rewrites/nginx/crmeb.conf b/pkg/embed/rewrites/nginx/crmeb.conf new file mode 100644 index 00000000..f72172e8 --- /dev/null +++ b/pkg/embed/rewrites/nginx/crmeb.conf @@ -0,0 +1,6 @@ +location / { + if (!-e $request_filename) { + rewrite ^(.*)$ /index.php?s=/$1 last; + break; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/dabr.conf b/pkg/embed/rewrites/nginx/dabr.conf new file mode 100644 index 00000000..5ac08629 --- /dev/null +++ b/pkg/embed/rewrites/nginx/dabr.conf @@ -0,0 +1,5 @@ +location / { + if (!-e $request_filename) { + rewrite ^/(.*)$ /index.php?q=$1 last; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/dbshop.conf b/pkg/embed/rewrites/nginx/dbshop.conf new file mode 100644 index 00000000..ce4f9e8e --- /dev/null +++ b/pkg/embed/rewrites/nginx/dbshop.conf @@ -0,0 +1,3 @@ +location / { + try_files $uri $uri/ /index.php$is_args$args; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/dedecms.conf b/pkg/embed/rewrites/nginx/dedecms.conf new file mode 100644 index 00000000..a26368d6 --- /dev/null +++ b/pkg/embed/rewrites/nginx/dedecms.conf @@ -0,0 +1,10 @@ +rewrite "^/list-([0-9]+).html$" /plus/list.php?tid=$1 last; +rewrite "^/list-([0-9]+)-([0-9]+)-([0-9]+).html$" /plus/list.php?tid=$1&totalresult=$2&PageNo=$3 last; +rewrite "^/view-([0-9]+)-1.html$" /plus/view.php?arcID=$1 last; +rewrite "^/view-([0-9]+)-([0-9]+).html$" /plus/view.php?aid=$1&pageno=$2 last; +rewrite "^/plus/list-([0-9]+).html$" /plus/list.php?tid=$1 last; +rewrite "^/plus/list-([0-9]+)-([0-9]+)-([0-9]+).html$" /plus/list.php?tid=$1&totalresult=$2&PageNo=$3 last; +rewrite "^/plus/view-([0-9]+)-1.html$" /plus/view.php?arcID=$1 last; +rewrite "^/plus/view-([0-9]+)-([0-9]+).html$" /plus/view.php?aid=$1&pageno=$2 last; +rewrite "^/tags.html$" /tags.php last; +rewrite "^/tag-([0-9]+)-([0-9]+).html$" /tags.php?/$1/$2/ last; \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/discuz.conf b/pkg/embed/rewrites/nginx/discuz.conf new file mode 100644 index 00000000..cd7793a3 --- /dev/null +++ b/pkg/embed/rewrites/nginx/discuz.conf @@ -0,0 +1,7 @@ +location / { + rewrite ^/archiver/((fid|tid)-[w-]+.html)$ /archiver/index.php?$1 last; + rewrite ^/forum-([0-9]+)-([0-9]+).html$ /forumdisplay.php?fid=$1&page=$2 last; + rewrite ^/thread-([0-9]+)-([0-9]+)-([0-9]+).html$ /viewthread.php?tid=$1&extra=page%3D$3&page=$2 last; + rewrite ^/space-(username|uid)-(.+).html$ /space.php?$1=$2 last; + rewrite ^/tag-(.+).html$ /tag.php?name=$1 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/discuzq.conf b/pkg/embed/rewrites/nginx/discuzq.conf new file mode 100644 index 00000000..598229f3 --- /dev/null +++ b/pkg/embed/rewrites/nginx/discuzq.conf @@ -0,0 +1,3 @@ +location / { + try_files $uri $uri/ /index.php$is_args$query_string; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/discuzx.conf b/pkg/embed/rewrites/nginx/discuzx.conf new file mode 100644 index 00000000..5f340f46 --- /dev/null +++ b/pkg/embed/rewrites/nginx/discuzx.conf @@ -0,0 +1,14 @@ +location / { + rewrite ^([^.]*)/topic-(.+).html$ $1/portal.php?mod=topic&topic=$2 last; + rewrite ^([^.]*)/article-([0-9]+)-([0-9]+).html$ $1/portal.php?mod=view&aid=$2&page=$3 last; + rewrite ^([^.]*)/forum-(w+)-([0-9]+).html$ $1/forum.php?mod=forumdisplay&fid=$2&page=$3 last; + rewrite ^([^.]*)/thread-([0-9]+)-([0-9]+)-([0-9]+).html$ $1/forum.php?mod=viewthread&tid=$2&extra=page%3D$4&page=$3 last; + rewrite ^([^.]*)/group-([0-9]+)-([0-9]+).html$ $1/forum.php?mod=group&fid=$2&page=$3 last; + rewrite ^([^.]*)/space-(username|uid)-(.+).html$ $1/home.php?mod=space&$2=$3 last; + rewrite ^([^.]*)/blog-([0-9]+)-([0-9]+).html$ $1/home.php?mod=space&uid=$2&do=blog&id=$3 last; + rewrite ^([^.]*)/(fid|tid)-([0-9]+).html$ $1/index.php?action=$2&value=$3 last; + rewrite ^([^.]*)/([a-z]+[a-z0-9_]*)-([a-z0-9_-]+).html$ $1/plugin.php?id=$2:$3 last; + if (!-e $request_filename) { + return 404; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/drupal.conf b/pkg/embed/rewrites/nginx/drupal.conf new file mode 100644 index 00000000..f1c70487 --- /dev/null +++ b/pkg/embed/rewrites/nginx/drupal.conf @@ -0,0 +1,3 @@ +if (!-e $request_filename) { + rewrite ^/(.*)$ /index.php?q=$1 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/ecshop.conf b/pkg/embed/rewrites/nginx/ecshop.conf new file mode 100644 index 00000000..1a0c4f17 --- /dev/null +++ b/pkg/embed/rewrites/nginx/ecshop.conf @@ -0,0 +1,37 @@ +location / { + if (!-e $request_filename) { + rewrite "^/index.html" /index.php last; + rewrite "^/category$" /index.php last; + rewrite "^/feed-c([0-9]+).xml$" /feed.php?cat=$1 last; + rewrite "^/feed-b([0-9]+).xml$" /feed.php?brand=$1 last; + rewrite "^/feed.xml$" /feed.php last; + rewrite "^/category-([0-9]+)-b([0-9]+)-min([0-9]+)-max([0-9]+)-attr([^-]*)-([0-9]+)-(.+)-([a-zA-Z]+)(.*).html$" /category.php?id=$1&brand=$2&price_min=$3&price_max=$4&filter_attr=$5&page=$6&sort=$7&order=$8 last; + rewrite "^/category-([0-9]+)-b([0-9]+)-min([0-9]+)-max([0-9]+)-attr([^-]*)(.*).html$" /category.php?id=$1&brand=$2&price_min=$3&price_max=$4&filter_attr=$5 last; + rewrite "^/category-([0-9]+)-b([0-9]+)-([0-9]+)-(.+)-([a-zA-Z]+)(.*).html$" /category.php?id=$1&brand=$2&page=$3&sort=$4&order=$5 last; + rewrite "^/category-([0-9]+)-b([0-9]+)-([0-9]+)(.*).html$" /category.php?id=$1&brand=$2&page=$3 last; + rewrite "^/category-([0-9]+)-b([0-9]+)(.*).html$" /category.php?id=$1&brand=$2 last; + rewrite "^/category-([0-9]+)(.*).html$" /category.php?id=$1 last; + rewrite "^/goods-([0-9]+)(.*).html" /goods.php?id=$1 last; + rewrite "^/article_cat-([0-9]+)-([0-9]+)-(.+)-([a-zA-Z]+)(.*).html$" /article_cat.php?id=$1&page=$2&sort=$3&order=$4 last; + rewrite "^/article_cat-([0-9]+)-([0-9]+)(.*).html$" /article_cat.php?id=$1&page=$2 last; + rewrite "^/article_cat-([0-9]+)(.*).html$" /article_cat.php?id=$1 last; + rewrite "^/article-([0-9]+)(.*).html$" /article.php?id=$1 last; + rewrite "^/brand-([0-9]+)-c([0-9]+)-([0-9]+)-(.+)-([a-zA-Z]+).html" /brand.php?id=$1&cat=$2&page=$3&sort=$4&order=$5 last; + rewrite "^/brand-([0-9]+)-c([0-9]+)-([0-9]+)(.*).html" /brand.php?id=$1&cat=$2&page=$3 last; + rewrite "^/brand-([0-9]+)-c([0-9]+)(.*).html" /brand.php?id=$1&cat=$2 last; + rewrite "^/brand-([0-9]+)(.*).html" /brand.php?id=$1 last; + rewrite "^/tag-(.*).html" /search.php?keywords=$1 last; + rewrite "^/snatch-([0-9]+).html$" /snatch.php?id=$1 last; + rewrite "^/group_buy-([0-9]+).html$" /group_buy.php?act=view&id=$1 last; + rewrite "^/auction-([0-9]+).html$" /auction.php?act=view&id=$1 last; + rewrite "^/exchange-id([0-9]+)(.*).html$" /exchange.php?id=$1&act=view last; + rewrite "^/exchange-([0-9]+)-min([0-9]+)-max([0-9]+)-([0-9]+)-(.+)-([a-zA-Z]+)(.*).html$" /exchange.php?cat_id=$1&integral_min=$2&integral_max=$3&page=$4&sort=$5&order=$6 last; + rewrite "^/exchange-([0-9]+)-([0-9]+)-(.+)-([a-zA-Z]+)(.*).html$" /exchange.php?cat_id=$1&page=$2&sort=$3&order=$4 last; + rewrite "^/exchange-([0-9]+)-([0-9]+)(.*).html$" /exchange.php?cat_id=$1&page=$2 last; + rewrite "^/exchange-([0-9]+)(.*).html$" /exchange.php?cat_id=$1 last; + } + + if (!-e $request_filename) { + return 404; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/edusoho.conf b/pkg/embed/rewrites/nginx/edusoho.conf new file mode 100644 index 00000000..b0099dcf --- /dev/null +++ b/pkg/embed/rewrites/nginx/edusoho.conf @@ -0,0 +1,8 @@ +location / { + index app.php; + try_files $uri @rewriteapp; +} + +location @rewriteapp { + rewrite ^(.*)$ /app.php/$1 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/emlog.conf b/pkg/embed/rewrites/nginx/emlog.conf new file mode 100644 index 00000000..ce4f9e8e --- /dev/null +++ b/pkg/embed/rewrites/nginx/emlog.conf @@ -0,0 +1,3 @@ +location / { + try_files $uri $uri/ /index.php$is_args$args; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/empirecms.conf b/pkg/embed/rewrites/nginx/empirecms.conf new file mode 100644 index 00000000..6ffcaaa9 --- /dev/null +++ b/pkg/embed/rewrites/nginx/empirecms.conf @@ -0,0 +1,8 @@ +rewrite ^([^.]*)/listinfo-(.+?)-(.+?).html$ $1/e/action/ListInfo/index.php?classid=$2&page=$3 last; +rewrite ^([^.]*)/showinfo-(.+?)-(.+?)-(.+?).html$ $1/e/action/ShowInfo.php?classid=$2&id=$3&page=$4 last; +rewrite ^([^.]*)/infotype-(.+?)-(.+?).html$ $1/e/action/InfoType/index.php?ttid=$2&page=$3 last; +rewrite ^([^.]*)/tags-(.+?)-(.+?).html$ $1/e/tags/index.php?tagname=$2&page=$3 last; +rewrite ^([^.]*)/comment-(.+?)-(.+?)-(.+?)-(.+?)-(.+?)-(.+?).html$ $1/e/pl/index.php?doaction=$2&classid=$3&id=$4&page=$5&myorder=$6&tempid=$7 last; +if (!-e $request_filename) { + return 404; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/laravel.conf b/pkg/embed/rewrites/nginx/laravel.conf new file mode 100644 index 00000000..598229f3 --- /dev/null +++ b/pkg/embed/rewrites/nginx/laravel.conf @@ -0,0 +1,3 @@ +location / { + try_files $uri $uri/ /index.php$is_args$query_string; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/maccms.conf b/pkg/embed/rewrites/nginx/maccms.conf new file mode 100644 index 00000000..b59deb64 --- /dev/null +++ b/pkg/embed/rewrites/nginx/maccms.conf @@ -0,0 +1,5 @@ +rewrite ^/vod-(.*)$ /index.php?m=vod-$1 break; +rewrite ^/art-(.*)$ /index.php?m=art-$1 break; +rewrite ^/gbook-(.*)$ /index.php?m=gbook-$1 break; +rewrite ^/label-(.*)$ /index.php?m=label-$1 break; +rewrite ^/map-(.*)$ /index.php?m=map-$1 break; \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/niushop.conf b/pkg/embed/rewrites/nginx/niushop.conf new file mode 100644 index 00000000..aeea9cbe --- /dev/null +++ b/pkg/embed/rewrites/nginx/niushop.conf @@ -0,0 +1,6 @@ +location / { + if (!-e $request_filename) { + rewrite ^(.*)$ /index.php?s=$1 last; + break; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/pbootcms.conf b/pkg/embed/rewrites/nginx/pbootcms.conf new file mode 100644 index 00000000..67089c37 --- /dev/null +++ b/pkg/embed/rewrites/nginx/pbootcms.conf @@ -0,0 +1,6 @@ +location / { + if (!-e $request_filename) { + rewrite ^/index.php(.*)$ /index.php?p=$1 last; + rewrite ^(.*)$ /index.php?s=$1 last; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/phpcms.conf b/pkg/embed/rewrites/nginx/phpcms.conf new file mode 100644 index 00000000..04ffd9c0 --- /dev/null +++ b/pkg/embed/rewrites/nginx/phpcms.conf @@ -0,0 +1,9 @@ +location / { + ###以下为PHPCMS伪静态 + rewrite ^(.*)show-([0-9]+)-([0-9]+).html$ $1/show.php?itemid=$2&page=$3; + rewrite ^(.*)list-([0-9]+)-([0-9]+).html$ $1/list.php?catid=$2&page=$3; + rewrite ^(.*)show-([0-9]+).html$ $1/show.php?specialid=$2; + ####以下为PHPWind伪静态 + rewrite ^(.*)-htm-(.*)$ $1.php?$2 last; + rewrite ^(.*)/simple/([a-z0-9\_]+.html)$ $1/simple/index.php?$2 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/phpwind.conf b/pkg/embed/rewrites/nginx/phpwind.conf new file mode 100644 index 00000000..f0f05823 --- /dev/null +++ b/pkg/embed/rewrites/nginx/phpwind.conf @@ -0,0 +1,4 @@ +location / { + rewrite ^(.*)-htm-(.*)$ $1.php?$2 last; + rewrite ^(.*)/simple/([a-z0-9\_]+.html)$ $1/simple/index.php?$2 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/sablog.conf b/pkg/embed/rewrites/nginx/sablog.conf new file mode 100644 index 00000000..e85841c4 --- /dev/null +++ b/pkg/embed/rewrites/nginx/sablog.conf @@ -0,0 +1,16 @@ +location / { + rewrite "^/date/([0-9]{6})/?([0-9]+)?/?$" /index.php?action=article&setdate=$1&page=$2 last; + rewrite ^/page/([0-9]+)?/?$ /index.php?action=article&page=$1 last; + rewrite ^/category/([0-9]+)/?([0-9]+)?/?$ /index.php?action=article&cid=$1&page=$2 last; + rewrite ^/category/([^/]+)/?([0-9]+)?/?$ /index.php?action=article&curl=$1&page=$2 last; + rewrite ^/(archives|search|article|links)/?$ /index.php?action=$1 last; + rewrite ^/(comments|tagslist|trackbacks|article)/?([0-9]+)?/?$ /index.php?action=$1&page=$2 last; + rewrite ^/tag/([^/]+)/?([0-9]+)?/?$ /index.php?action=article&item=$1&page=$2 last; + rewrite ^/archives/([0-9]+)/?([0-9]+)?/?$ /index.php?action=show&id=$1&page=$2 last; + rewrite ^/rss/([0-9]+)?/?$ /rss.php?cid=$1 last; + rewrite ^/rss/([^/]+)/?$ /rss.php?url=$1 last; + rewrite ^/uid/([0-9]+)/?([0-9]+)?/?$ /index.php?action=article&uid=$1&page=$2 last; + rewrite ^/user/([^/]+)/?([0-9]+)?/?$ /index.php?action=article&user=$1&page=$2 last; + rewrite sitemap.xml sitemap.php last; + rewrite ^(.*)/([0-9a-zA-Z-\_]+)/?([0-9]+)?/?$ $1/index.php?action=show&alias=$2&page=$3 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/seacms.conf b/pkg/embed/rewrites/nginx/seacms.conf new file mode 100644 index 00000000..17863753 --- /dev/null +++ b/pkg/embed/rewrites/nginx/seacms.conf @@ -0,0 +1,11 @@ +location / { + rewrite ^/frim/index(.+?).html$ /list/index.php?$1 last; + rewrite ^/movie/index(.+?).html$ /detail/index.php?$1 last; + rewrite ^/play/([0-9]+)-([0-9]+)-([0-9]+).html$ /video/index.php?$1-$2-$3 last; + rewrite ^/topic/index(.+?).html$ /topic/index.php?$1 last; + rewrite ^/topiclist/index(.+?).html$ /topiclist/index.php?$1 last; + rewrite ^/index.html$ index.php permanent; + rewrite ^/news.html$ news/ permanent; + rewrite ^/part/index(.+?).html$ /articlelist/index.php?$1 last; + rewrite ^/article/index(.+?).html$ /article/index.php?$1 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/shopex.conf b/pkg/embed/rewrites/nginx/shopex.conf new file mode 100644 index 00000000..e6543eca --- /dev/null +++ b/pkg/embed/rewrites/nginx/shopex.conf @@ -0,0 +1,5 @@ +location / { + if (!-e $request_filename) { + rewrite ^/(.+.(html|xml|json|htm|php|jsp|asp|shtml))$ /index.php?$1 last; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/shopwind.conf b/pkg/embed/rewrites/nginx/shopwind.conf new file mode 100644 index 00000000..1583aac4 --- /dev/null +++ b/pkg/embed/rewrites/nginx/shopwind.conf @@ -0,0 +1,14 @@ +location / { + #Redirect everything that isn't a real file to index.php + try_files $uri $uri/ /index.php$is_args$args; +} +#If you want a single domain name at the front and back ends +location /admin { + try_files $uri $uri/ /admin/index.php$is_args$args; +} +location /mobile { + try_files $uri $uri/ /mobile/index.php$is_args$args; +} +location /api { + try_files $uri $uri/ /api/index.php$is_args$args; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/thinkphp.conf b/pkg/embed/rewrites/nginx/thinkphp.conf new file mode 100644 index 00000000..9048a269 --- /dev/null +++ b/pkg/embed/rewrites/nginx/thinkphp.conf @@ -0,0 +1,8 @@ +location ~* (runtime|application)/ { + return 403; +} +location / { + if (!-e $request_filename) { + rewrite ^(.*)$ /index.php?s=$1 last; break; + } +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/typecho.conf b/pkg/embed/rewrites/nginx/typecho.conf new file mode 100644 index 00000000..ce4f9e8e --- /dev/null +++ b/pkg/embed/rewrites/nginx/typecho.conf @@ -0,0 +1,3 @@ +location / { + try_files $uri $uri/ /index.php$is_args$args; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/wordpress-multisite.conf b/pkg/embed/rewrites/nginx/wordpress-multisite.conf new file mode 100644 index 00000000..d279a9d6 --- /dev/null +++ b/pkg/embed/rewrites/nginx/wordpress-multisite.conf @@ -0,0 +1,9 @@ +location / { + try_files $uri $uri/ /index.php$is_args$args ; +} + +if (!-e $request_filename) { + rewrite /wp-admin$ $scheme://$host$request_uri/ permanent; + rewrite ^/([^/]+)?(/wp-(content|admin|includes).*) $2 last; + rewrite ^/([^/]+)?(/[^/]+.php)$ $2 last; +} \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/wordpress.conf b/pkg/embed/rewrites/nginx/wordpress.conf new file mode 100644 index 00000000..6b08372b --- /dev/null +++ b/pkg/embed/rewrites/nginx/wordpress.conf @@ -0,0 +1,5 @@ +location / { + try_files $uri $uri/ /index.php$is_args$args; +} + +rewrite /wp-admin$ $scheme://$host$uri/ permanent; \ No newline at end of file diff --git a/pkg/embed/rewrites/nginx/zblog.conf b/pkg/embed/rewrites/nginx/zblog.conf new file mode 100644 index 00000000..39e357ee --- /dev/null +++ b/pkg/embed/rewrites/nginx/zblog.conf @@ -0,0 +1,9 @@ +if (-f $request_filename/index.html) { + rewrite (.*) $1/index.html break; +} +if (-f $request_filename/index.php) { + rewrite (.*) $1/index.php; +} +if (!-f $request_filename) { + rewrite (.*) /index.php; +} \ No newline at end of file