Total Pageviews

Friday 1 November 2024

基于php的静态博客程序lina

 static blog generator written in PHP with the powerful of Laravel blade template engine. 

lina.daudau.cc

Lina - lightweight and blazing fast static blog generator

Lina is an opinionated flat-file CMS for who want a simple and fast blog. Lina uses Blade template engine, so you can use all Blade features.

Features

  • Blazing fast: Lina is a lightweight and superfast static blog generator.
  • Written in PHP: so if you hate Javascript, Lina is for you.
  • Blade template engine: you can use all Blade features.'
  • Minimalistic: Lina is a static blog generator. It's not a full-fledged CMS.
  • Deploy everywhere! You know, just html files 🤣

Requirements

  • PHP 8.3

Getting started

There are some ways to install Lina:

Require Lina as dependency, with this option, you can keep lina up-to-date easily.

mkdir my-blog && cd my-blog && composer init --name=linaphp/blog --no-interaction --require=bangnokia/lina:^0.5 && composer install
./vendor/bin/lina new . # scaffolding a new blog skeleton in the current directory
./vendor/bin/lina serve # start a development server and happy writing

Or install Lina as global composer package

composer global require linaphp/lina
lina new my-blog
lina serve

Or you can use the phar file

curl -LO https://github.com/linaphp/lina/releases/latest/download/lina.phar && chmod +x lina.phar

Folder structure

In case you want to migrate from another blog platform, you can check the base structure of Lina

content/
    posts/
        2020-11-01-hello.md
    index.md
resources/
    views/
        index.blade.php
        post.blade.php
public/ 
    images/
    style.css
  • content directory is where you store your markdown content file.
  • resources/views directory is where you store your blade template.
  • public directory is where you store your assets like images, css, ... This folder is also where all the generated files are stored. So please remember to add your custom files to .gitignore if you want to store them in git

We really recommend you to prefix your content file with the date, so it will easy to sort and find your content. Lina automatically strip the date from the slug, so you don't need to worry about the url.

Helper functions

There are some functions that you can use to programmatically access your content.

Get all content in a directory

Get all the content in a directory. The content will be sorted by the date in the filename.

foreach (lina()->index('post') as $post) {
    echo $post->title;
}

Get a single content

$post = lina()->get('posts/2020-11-01-hello.md');

Deployments

Lina can be deployed to any static hosting provider. Here are some examples: Github pages, Netlify, Vercel, Cloudflare pages, ...

Deploy on Github pages

So you please modify the file .github/workflows/deploy.yml to match your demand.

Deploy on Cloudflare pages

We also provide a configuration file for Cloudflare pages. You can find it in cloudflare-page.sh. You can modify it to match your demand. Also you need to change the Build configuration like this. Cloudflare deploy

Built with Lina

So, you know, at least that's me.

from https://github.com/linaphp/lina

 

搭建基于go和js的静态博客程序norcia

 cd ~

git clone https://github.com/Besfim/Norcia/

cd Norcia

go build Norcia.go (此命令会在当前目录下,生成Norcia.exe)

$ ls
Norcia.exe*  Norcia_drawin_amd64  Norcia_win_amd64.exe*  TODO.md        blog.html  config.json  document/  google-code-prettify/  img/        js/          tags.html
Norcia.go    Norcia_linux_amd64   README.md              archives.html  build.sh*  css/         fonts/     icons/   index.html  search.html (可见当前目录~/norcia就是静态网站的根目录

$ ./Norcia.exe -p

显示:

...

---------- Norcia 博客预览服务 ----------

请访问: http://localhost:8666/index.html

按ctrl+c,终止运行 ./Norcia.exe -p

新建源帖:

cd document

nano  快乐的节日.md

cat 快乐的节日.md

显示:

此处写正文或html codes即可。

cd ..

nano config.json

(在 "articles": [ 这行的下一行加上:

{
            "title": "快乐的节日",
            "tag": "music,life",
            "create": "2024-11-01 09:26",
            "update": "2024-11-01 09:26",
            "mini": "这是一 首歌"
        },

 然后,

$ ./Norcia.exe -p 即可看到网站更新后的效果。

演示网站:

https://norcia.dujun.bf/

https://besfim.github.io/Norcia/

https://zesty-torrone-5b488a.netlify.app/

项目地址:https://github.com/Besfim/Norcia




 

 




cd