Delphi ActiveX
Delphi ActiveX
WordPress Create Post
See more WordPress Examples
Demonstrates how to create a WordPress post.Chilkat Delphi ActiveX Downloads
uses
Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
...
procedure TForm1.Button1Click(Sender: TObject);
var
success: Integer;
http: TChilkatHttp;
json: TChilkatJsonObject;
tagIdx: Integer;
resp: TChilkatHttpResponse;
jResp: TChilkatJsonObject;
begin
success := 0;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := TChilkatHttp.Create(Self);
// Use your WordPress login, such as "admin", not the application name.
http.Login := 'wp_username';
// Use the application password, such as "Nths RwVH eDJ4 weNZ orMN jabq"
// See WordPress Application Passwords Plugin
http.Password := 'app_password';
http.BasicAuth := 1;
// Note: For this to work, you'll likely need to update your .htaccess file on your WordPress server.
// Otherwise you'll get this error:
//
// 401 : Sorry, you are not allowed to create posts as this user
//
// Your default .htaccess file probably looks like this:
//
// <IfModule mod_rewrite.c>
// RewriteEngine On
// RewriteBase /
// RewriteRule ^index\.php$ -
// RewriteCond %{REQUEST_FILENAME} !-f
// RewriteCond %{REQUEST_FILENAME} !-d
// RewriteRule . /index.php
// </IfModule>
// # END WordPress
//
// Add the following line immediately after the "RewriteEngine On" line: RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization}]
// Your .htaccess file should look like this after the edit:
//
// <IfModule mod_rewrite.c>
// RewriteEngine On
// RewriteRule .* - [E=REMOTE_USER:%{HTTP:Authorization}]
// RewriteBase /
// RewriteRule ^index\.php$ -
// RewriteCond %{REQUEST_FILENAME} !-f
// RewriteCond %{REQUEST_FILENAME} !-d
// RewriteRule . /index.php
// </IfModule>
// # END WordPress
json := TChilkatJsonObject.Create(Self);
json.UpdateString('title','This is a test post');
json.UpdateString('content','<p>This is the HTML body of my post</p>');
// The status can be "draft" or "publish"
json.UpdateString('status','draft');
// Add tags -- but you need to know the ID of an existing tag.
// See Chilkat's other WordPress example for creating a tag, or getting the ID of an existing tag.
tagIdx := 0;
json.I := tagIdx;
// When Chilkat sees the literal string "[i]" in the JSON path, it replaces the "i" with the value of the "I" property.
json.UpdateInt('tags[i]',56);
tagIdx := tagIdx + 1;
json.I := tagIdx;
json.UpdateInt('tags[i]',75);
// ..
resp := TChilkatHttpResponse.Create(Self);
success := http.HttpJson('POST','https://cknotes.com/wp-json/wp/v2/posts',json.ControlInterface,'application/json',resp.ControlInterface);
if (success = 0) then
begin
Memo1.Lines.Add(http.LastErrorText);
Exit;
end;
if (resp.StatusCode <> 201) then
begin
Memo1.Lines.Add(resp.BodyStr);
Memo1.Lines.Add('status code = ' + IntToStr(resp.StatusCode));
Exit;
end;
jResp := TChilkatJsonObject.Create(Self);
jResp.Load(resp.BodyStr);
Memo1.Lines.Add('Post ID = ' + IntToStr(jResp.IntOf('id')));
Memo1.Lines.Add('Post URL = ' + jResp.StringOf('link'));
end;