using System; using System.Diagnostics; using System.Threading.Tasks; using DotNetCore.CAP; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Mvc; namespace Sample.Kafka.SqlServer.Controllers { public class Person { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } public override string ToString() { return "Name:" + Name + ";Age:" + Age; } } [Route("api/[controller]")] public class ValuesController : Controller, ICapSubscribe { private readonly ICapPublisher _capBus; private readonly AppDbContext _dbContext; public ValuesController(ICapPublisher producer, AppDbContext dbContext) { _capBus = producer; _dbContext = dbContext; } [Route("~/publish")] public IActionResult PublishMessage() { _capBus.Publish("sample.rabbitmq.sqlserver.order.check", DateTime.Now); //var person = new Person //{ // Name = "杨晓东", // Age = 11, // Id = 23 //}; //_capBus.Publish("sample.rabbitmq.mysql33333", person); return Ok(); } [Route("~/publishWithTrans")] public async Task PublishMessageWithTransaction() { using (var trans = await _dbContext.Database.BeginTransactionAsync()) { await _capBus.PublishAsync("sample.rabbitmq.mysql", ""); trans.Commit(); } return Ok(); } [CapSubscribe("sample.rabbitmq.mysql33333",Group ="Test.Group")] public void KafkaTest22(Person person) { var aa = _dbContext.Database; _dbContext.Dispose(); Console.WriteLine("[sample.kafka.sqlserver] message received " + person.ToString()); Debug.WriteLine("[sample.kafka.sqlserver] message received " + person.ToString()); } //[CapSubscribe("sample.rabbitmq.mysql22222")] //public void KafkaTest22(DateTime time) //{ // Console.WriteLine("[sample.kafka.sqlserver] message received " + time.ToString()); // Debug.WriteLine("[sample.kafka.sqlserver] message received " + time.ToString()); //} [CapSubscribe("sample.rabbitmq.mysql22222")] public async Task KafkaTest33(DateTime time) { Console.WriteLine("[sample.kafka.sqlserver] message received " + time.ToString()); Debug.WriteLine("[sample.kafka.sqlserver] message received " + time.ToString()); return await Task.FromResult(time); } [NonAction] [CapSubscribe("sample.kafka.sqlserver3")] [CapSubscribe("sample.kafka.sqlserver4")] public void KafkaTest() { Console.WriteLine("[sample.kafka.sqlserver] message received"); Debug.WriteLine("[sample.kafka.sqlserver] message received"); } } }