ここにデフォルトのC#ベースのHTTPトリガーがあり、「Hello Name」というデータをService Busトピック(作成済み)に送信したいと思います。ポータルでコーディングしています。
Service Bus出力バインディングの方法
これは機能していません。何かヘルプはありますか?
-Service Busを処理するための参照がありませんか?
-サービスバスの接続を定義する方法Functions.jsonはどこにありますか
-サービスバスにメッセージを送信する方法
//This FunctionApp get triggered by HTTP and send message to Azure Service Bus
using System;
using System.IO;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.Azure.WebJobs;
using Microsoft.Azure.WebJobs.Extensions.Http;
using Microsoft.AspNetCore.Http;
using Microsoft.Extensions.Logging;
using Newtonsoft.Json;
namespace Company.Function
{
public static class HttpTriggerCSharp1
{
[FunctionName("HttpTriggerCSharp1")]
[return: ServiceBus("myqueue", Connection = "ServiceBusConnection")] // I added this for SB Output. Where to define.
public static async Task<IActionResult> Run(
[HttpTrigger(AuthorizationLevel.Anonymous, "get", "post", Route = null)] HttpRequest req,
ILogger log)
{
log.LogInformation("C# HTTP trigger function processed a request.");
string name = req.Query["name"];
string requestBody = await new StreamReader(req.Body).ReadToEndAsync();
dynamic data = JsonConvert.DeserializeObject(requestBody);
name = name ?? data?.name;
string responseMessage = string.IsNullOrEmpty(name)
? "This HTTP triggered function executed successfully. Pass a name in the query string or in the request body for a personalized response."
: $"Hello, {name}. This HTTP triggered function executed successfully.";
return new OkObjectResult(responseMessage);
// I added this for SB Output
return responseMessage;
}
}
}
最初に Microsoft.Azure.WebJobs.Extensions.ServiceBus NuGetパッケージをインストールしてください。次に、プロジェクトでそれを使用していることを確認します。
using Microsoft.Azure.WebJobs.Extensions.ServiceBus;
エラーがないことを確認するために、プロジェクトをクリーンアップしてビルドしてください。
次に、"ServiceBusConnection"
ファイル内にlocal.settings.json
接続文字列があることを確認する必要があります。
{
"IsEncrypted": false,
"Values": {
"FUNCTIONS_WORKER_RUNTIME": "dotnet",
"ServiceBusConnection": "Endpoint=sb://...",
}
}
Azureポータル->サービスバスの名前空間->共有アクセスポリシー-> RootManageSharedAccessKey->プライマリ接続文字列に移動すると取得できます。この接続文字列をコピーして"ServiceBusConnection"
内に貼り付けます。 セカンダリ接続文字列も使用できます。
注:サービスバスキュー/トピックにも共有アクセスポリシーがあります。したがって、サービスバスの名前空間レベルのアクセスポリシーを使用しない場合は、キュー/トピックレベルでポリシーを作成できるため、関数アプリは名前空間で定義されたキュー/トピックにのみアクセスできます。
また、関数アプリを公開する場合は、"ServiceBusConnection"
はローカルテストでのみ使用されるため、local.settings.json
の設定アプリケーション設定を作成する必要があります。