A blogging engine based on HTML5 and ASP.NET. For an ASP.NET Core version, see Miniblog.Core.
Live demo: http://miniblog.azurewebsites.net/
In search for custom designed themes for MiniBlog? Click here.
Simple, flexible and powerful
A minimal, yet full featured blog engine using ASP.NET Razor Web Pages. Perfect for the blogger who wants to selfhost a blog.
- Best-in-class performance
- Gets a perfect score of 100/100 on Google Page Speed
- Uses CDN for Bootstrap and jQuery in release mode (debug="false")
- Easy setting for serving static files from another domain.
- Supports the ASP.NET Reverse Proxy
- Open Live Writer (OLW) support
- Optimized for OLW
- Assumes OLW is the main way to write posts
- You don't have to use OLW (but you should)
- RSS and ATOM feeds
- Schedule posts to be published on a future date
- Get feedback on an unpublished post by sending a preview link
- SEO optimized
- Uses HTML 5 microdata to add semantic meaning
- Support for robots.txt and sitemap.xml
- Theming support
- Based on Bootstrap themes. Makes it easy to customize your blog
- Comes with a one-column, two-column, and off-canvas theme
- No database required
- Uses the same XML format as BlogEngine.NET
- Move your existing blog to MiniBlog using MiniBlog Formatter
- Inline editing of blog posts
- Comments support
- Gravatar support
- Can easily be replaced by 3rd-party commenting system
- Drag 'n drop images to upload
- Automatically optimizes uploaded images
- Uses latest technologies
- OpenGraph enabled
- Based on jQuery and Bootstrap
- Best-in-class accessibility
- Mobile friendly
- Works on any host including Windows Azure Websites
Why another blog engine?
7 years have passed since I started the BlogEngine.NET project. It was using cutting edge technology for its time and quickly became the most popular blogging platform using ASP.NET.
The MiniBlog was born as a test to see what a modern blog engine could look like today with the latest ASP.NET and HTML 5 technologies. Just like with BlogEngine.NET, the goal was to see how small and simple such a blog engine could be.
This is the result.
Connecting with Open Live Writer (OLW)
To connect to MiniBlog with Open Live Writer:
Launch Open Live Writer
If you have not used Open Live Writer to connect to a blog you will get a dialog window asking you to specify what blog service you use. If you have already connected Open Live Writer to a blog, you can go to Blogs -> Add blog account... and get to the same dialog window.
In the What blog service do you use? dialog window you will tick the Other services radio option and click next.
The Add a blog account dialog window will ask you for the web address of your blog, the username and password. The web address is the root address of your site. For example, use http://miniblog.azurewebsites.net/ for the live demo site.
The Download Blog Theme dialog window will let you know Open Live Writer can download your blog theme if you allow it to publish a temporary post. Selecting yes will allow you to view how your posts will look directly from the Open Live Writer editor.
The Select blog type dialog window will let you know Open Live Writer was not able to detect your blog type. It will ask you for the type of blog and the remote posting URL.
Type of blog that you are using: Metaweblog API
Remote posting URL for your blog: http://<root-address>/metaweblog
The Your blog has been set up dialog window will let you give your blog a nickname for the Open Live Writer instance. Change that if you want and click finish to get to posting!
Open Live Writer can be downloaded at:
Configuring MiniBlog as Virtual Application
MiniBlog is very compact and can be configured as a Virtual Application so you'd be able to use it alongside your existing websites.
For example if you've got a running ASP.NET website at
http://yourexamplesite.com/ and you want to setup a blog under
/blog/ path, you could setup
http://yourexamplesite.com/blog/ with a few simple tweaks in web.config settings:
appSettingsto the virtual path that you've configured for MiniBlog. Example with path
<add key="blog:path" value="blog"/>
- Update the
pathattribute of all the
<handlers>in web.config. Example with path
<handlers> <remove name="CommentHandler"/> <add name="CommentHandler" verb="*" type="CommentHandler" path="/blog/comment.ashx"/> <remove name="PostHandler"/> <add name="PostHandler" verb="POST" type="PostHandler" path="/blog/post.ashx"/> <remove name="MetaWebLogHandler"/> <add name="MetaWebLogHandler" verb="POST,GET" type="MetaWeblogHandler" path="/blog/metaweblog"/> <remove name="FeedHandler"/> <add name="FeedHandler" verb="GET" type="FeedHandler" path="/blog/feed/*"/> <remove name="CssHandler"/> <add name="CssHandler" verb="GET" type="MinifyHandler" path="/blog*.css"/> <remove name="JsHandler"/> <add name="JsHandler" verb="GET" type="MinifyHandler" path="/blog*.js"/> </handlers> <httpErrors> <remove statusCode="404"/> <error statusCode="404" responseMode="ExecuteURL" path="/blog/404.cshtml"/> </httpErrors>
After changing the config all that is left is configuring a Virtual Application with the same path(ex.
blog) inside your IIS website.