AI Productivity · Claude · WordPress MCP
Publishing to WordPress with Claude and the WordPress MCP Connector
A practical guide to using Claude on claude.ai to draft, style, and publish blog posts directly to your WordPress site — with hard-won lessons on what WordPress strips, and how to work around it.
Several posts on this blog — including Word Embeddings Explained, SingIDBot, and the OpenClaw Telegram integration guide — were written, styled, and published entirely through Claude on claude.ai, using the WordPress MCP connector. This post documents exactly how that workflow operates, what problems arise, and how to resolve them.
The combination of Claude’s HTML generation capability and the WordPress MCP connector creates a surprisingly smooth authoring pipeline, provided you know the constraints WordPress imposes on custom HTML blocks. Those constraints are the non-obvious part, and they are addressed in detail below.
1. Prerequisites
Before you begin, the following need to be in place:
| Requirement | Details |
|---|---|
| Claude account on claude.ai | Free tier works; a Pro account gives longer contexts useful for large HTML posts. |
| WordPress.com site | The MCP connector works with WordPress.com-hosted blogs. Self-hosted WordPress.org sites are not directly supported by the connector. |
| WordPress MCP connector enabled | In claude.ai, go to Settings → Integrations (or Connectors) and enable the WordPress.com connector. Authenticate with your WordPress.com account. |
2. The Overall Workflow
The end-to-end process has three stages. Claude handles all of them in a single conversation.
Stage 1
Draft & Style
Provide Claude with your content and request a WordPress HTML block with inline CSS only. No <style> tags.
Stage 2
Review Output
Preview the rendered HTML in claude.ai artifacts. Request edits until the post looks correct.
Stage 3
Publish via MCP
Ask Claude to post using the WordPress connector. It checks categories and tags, creates any missing ones, then submits as a draft for your review.
The key prompt to kick off Stage 1:
For Stage 3, once the HTML is finalised:
3. How the WordPress MCP Connector Works
The MCP (Model Context Protocol) connector gives Claude direct access to your WordPress.com REST API. When you ask Claude to post, it performs these operations internally:
- Loads the connector via an internal tool search, resolving the
WordPress.com:wpcom-mcp-content-authoringtool. - Lists existing categories using
categories.liston your site to find IDs for any categories you want. - Lists existing tags using
tags.listto find or create the tags for the post. - Creates missing categories or tags using
categories.create/tags.createif they do not already exist on the site. - Creates the post using
posts.create, passing the HTML content, title, category IDs, tag IDs, and status (draftorpublish). - Returns the preview and edit URLs so you can open the draft in WordPress immediately.
The post content must be wrapped in a wp:html block comment:
<div style=”…”>…post content…</div>
<!– /wp:html –>
4. Problems Encountered — and How They Were Solved
The workflow is productive but not without friction. Several issues emerged across multiple posts on this blog. Each is documented here with its root cause and fix.
Problem 1: WordPress strips <style> blocks entirely
What happened: Early posts used a <style> tag defining CSS classes. WordPress silently removed it on save, stripping all styling.
Fix: Every CSS rule must be written as an inline style="..." attribute. Claude handles this when instructed: “Use inline CSS only. Do not use <style> tags.”
Problem 2: WordPress strips SVG elements
What happened: Inline SVG circuit diagrams were stripped on save, leaving blank spaces.
Fix: Replace SVG with HTML-native layout (see Problems 6 and 7 for the full technique). Instruction: “Do not use SVG. Use CSS flexbox and inline-block spans for all diagrams.”
Problem 3: <script> tags are blocked
What happened: JavaScript interactivity was silently discarded by WordPress content sanitisation.
Fix: All interactivity must be replaced with pure HTML/CSS alternatives. Standing instruction: “No <script> tags.”
Problem 4: API parameter case sensitivity
What happened: Passing "order": "DESC" returned a validation error.
Fix: Always use lowercase: "order": "desc".
Problem 5: Duplicate categories and tags
What happened: Claude created duplicate taxonomy terms without checking first.
Fix: Always call categories.list and tags.list before any creation step.
Problem 6: Unicode box-drawing characters and spacing break alignment in WordPress
What happened: Unicode box-drawing characters inside <pre> elements and spacing in monospace divs looked correct in the claude.ai artifact but misaligned in WordPress — the theme’s font renders these characters at inconsistent widths.
Fix: Replace character-based layout with CSS layout:
- Single-wire gates:
display:flex; align-items:centerrows withinline-blockwire spans and bordered gate boxes. - Column vectors and matrices:
display:flexcontainer withborder-left/border-rightbracket spans and<br>for rows.
Instruction: “Never use for alignment or Unicode box-drawing characters. Use display:flex and inline-block spans instead.”
Problem 7: Multi-wire circuit diagrams with vertical connectors require position:absolute
What happened: The CNOT gate in the Phase Kickback post required a vertical line connecting a control dot (●) on one wire to an XOR circle (⊕) on another. Multiple approaches failed: border-bottom/border-top on adjacent table cells created horizontal bars instead of a vertical line; rowspan="2" in real <table> elements was visually correct but the WordPress theme’s CSS overrode <td> padding, creating unwanted row spacing that inline styles alone could not override.
Fix: A three-part solution:
- Avoid theme td overrides: use
<div style="display:table-cell">instead of<td>— theme CSS targetingtdselectors does not apply to divs. - Vertical connector: two separate
display:flex; height:28pxrows inside aposition:relative; display:inline-blockwrapper, with aposition:absolute; width:2pxconnector div at a precisely calculatedleftvalue. - Asymmetric wire stubs: the control dot (12px wide) needs 21px wire stubs on each side; the XOR circle (20px wide) needs 17px stubs — these different widths keep both symbol centres at the same x-coordinate so the connector aligns with both. Wire stubs connect directly to the symbols with no padding gap between them.
Instruction: “For multi-wire circuits with vertical connections, use two flex rows in a position:relative wrapper with a position:absolute vertical connector. Wire stubs must touch each gate symbol directly with no padding gap.”
Tip: Let Claude Choose Categories and Tags Automatically
You do not need to specify categories and tags manually. Simply ask Claude to “use appropriate categories and tags” and it will inspect the existing taxonomy on your site, infer suitable terms from the post content, and create any new ones that are genuinely needed.
5. Step-by-Step: Posting via Claude and WordPress MCP
The following steps reproduce the exact workflow used to create and publish posts on this blog.
Step 1 — Enable the WordPress Connector in claude.ai
Go to claude.ai → Settings → Integrations. Find the WordPress.com connector and click Connect. Authorise it with your WordPress.com account.
Step 2 — Prepare your content and prompt Claude
Provide Claude with the raw content, a reference post URL, and the constraint set:
Use inline CSS only — no <style> tags, no <script> tags, no SVG.
Never use for alignment or Unicode box-drawing characters.
Use display:flex and inline-block spans for diagrams and vectors.
For multi-wire circuits: use position:relative wrapper + position:absolute connector.
Match the styling of: [URL of a reference post]
Topic: [your content here]
Step 3 — Review the artifact in claude.ai
Review layout, colours, and diagram rendering. Verify no <style> or <script> tags appear. Check that circuit wires touch gate symbols directly.
Step 4 — Trigger the WordPress MCP posting
Use appropriate categories and tags.
Status: draft
Claude will call categories.list and tags.list, create any missing terms, then execute posts.create and return the draft URLs.
Step 5 — Preview in WordPress and publish
Open the draft URL. If the Custom HTML block renders correctly, click Publish.
6. Installing the Workflow as a Reusable Skill
All the constraints from this guide are packaged as a downloadable Claude Skill. Once installed, the skill auto-loads every time you start a WordPress publishing task, so you never need to paste the prompt template manually again.
Step 1 — Enable Code Execution and File Creation
Go to Settings → Capabilities and toggle on Code Execution and File Creation. This is required for Claude to process the skill file when you upload it.
Step 2 — Open the Skills page
Navigate to https://claude.ai/customize/skills. Note: the Customize menu is only available in the browser version of Claude, not the mobile app. On mobile, use the direct link or enable Desktop site in your browser menu.
Step 3 — Upload the skill file
Click “+” → “+ Create skill” → “Upload a skill” → select wordpress-publish.skill → toggle it on.
Step 4 — Trigger in any new chat
In any new conversation, say “publish to WordPress” and Claude automatically loads all the constraints from this guide.
7. Quick Reference: Dos and Don’ts
| Do | Don’t |
|---|---|
Use style="..." on every element | Use <style> blocks or CSS classes |
Use display:flex + inline-block for single-wire gate diagrams and vectors | Use spacing or Unicode box-drawing characters for alignment |
Use position:relative wrapper + position:absolute connector for multi-wire circuits; wire stubs touching symbols directly | Use border-top/border-bottom on table cells to simulate vertical connectors |
Use <div style="display:table-cell"> to avoid WordPress theme td padding overrides | Rely on inline padding on actual <td> elements — theme CSS may override it |
Wrap content in <!-- wp:html --> | Use <svg> elements or <script> tags |
Use lowercase "order": "desc" in API params | Use uppercase "order": "DESC" |
Post as draft first and preview in WordPress | Publish directly without previewing the rendered block |
| Let Claude auto-select categories and tags | Create taxonomy terms without checking for existing ones first |
Set table header styles on <tr>, not <th> | Apply background colours to <th> elements |
Tip: Use a Reference Post to Anchor the Style
Giving Claude the URL of an existing post on your blog and asking it to match the styling is the fastest way to maintain visual consistency. The Word Embeddings post and the SingIDBot guide were both created this way, borrowing section card layout, banner colours, and code block styles from earlier posts in the series.
This article was generated with the assistance of Claude by Anthropic and posted via the WordPress MCP connector. ✨
Share this:
- Share on X (Opens in new window) X
- Share on Facebook (Opens in new window) Facebook
- Print (Opens in new window) Print
- Email a link to a friend (Opens in new window) Email
- Share on LinkedIn (Opens in new window) LinkedIn
- Share on Reddit (Opens in new window) Reddit
- Share on Tumblr (Opens in new window) Tumblr
- Share on Threads (Opens in new window) Threads
- Share on Pinterest (Opens in new window) Pinterest
- Share on Telegram (Opens in new window) Telegram
- Share on WhatsApp (Opens in new window) WhatsApp
- Share on Bluesky (Opens in new window) Bluesky