Drupal之微信小程序图片上传及创建文章

1. 微信小程序上传图片

wx.uploadFile
使用及详情请看官方文档
举个例子:

uploadFile: function () {
  wx.uploadFile({
    url: _global.domain + '/article/file/upload',
    filePath: this.imageFiles[0],
    name: 'file',
    formData:{
      'user': 'test'
    },
    success: function(res){
      console.log('Test upload image file.')
      console.log(res)
    }
  })
}

此处是举个例子将我本地的imageFiles数组中的第一个上传到了图中所示的url中。

2. 接收文件

这里就需要获取到文件并且解析它,将其移入到/site/file文件目录并且存入到数据库中。

if ($_FILES['file']) {
    $uri = file_unmanaged_copy($_FILES["file"]["tmp_name"], "public://2018-07/" . $_FILES["file"]["name"], FILE_EXISTS_RENAME);
    $createdFile = File::create([
        'uri' => $uri
    ]);
    $createdFile -> save();
}

解释一下是什么意思:

  1. PHP接受到的文件会将其存入到临时文件当中,根据$_FILES['file']['tmp_name'] 获取。

  2. file_unmanaged_copy 该方法有三个参数,第一个参数是待移动文件的位置,第二个参数是移动的位置及文件名,第三个参数则是如果文件重名,会在其后缀加上数字0,如果加上0也重名,则会在后面加上数字1。直到文件名不重复为止。

  3. 之后调用File->save() 存入数据库

3. 创建Content,并且引入已上传的图片

太过简单直接上代码

$file = File::load($createdFile->id());
$node = Node::create([
    'uid' => '1941562',
    'type' => 'bulletin',
    'title' => 'Test node',
    'body' => 'aaaaaaaaaaaaaaaaaaaaaaaa',
    'status' => 1,
    'promote' => 0,
    'sticky' => 0,
    'langcode' => LanguageInterface::LANGCODE_NOT_SPECIFIED,
    'created' => REQUEST_TIME,
    'changed' => REQUEST_TIME,
    'field_bulletin_image' => array($file,$file)
]);

$node->save();

这部分代码紧接着上一部分代码。
注:bulletin是node的机器码。field_bulletin_image也是,是该node的field的机器码。
这段代码作用就是创建一个node,将文章内容与视频图片绑定起来。

你可能感兴趣的:(Drupal之微信小程序图片上传及创建文章)