analizar la respuesta de solicitud de ofx

OFX, Open Financial Exchange, los archivos se utilizan para intercambiar información financiera. Se utiliza en sistemas cliente-servidor y en la nube. Entonces, el modelo de solicitud-respuesta se usa para intercambiar información financiera. Aprendamos la solicitud y respuesta OFX:

Parse OFX Request and Response: instalación de la API de C#

Aspose.Finance for .NET API admite varias funciones para procesar y analizar datos financieros. Puede descargarlo desde la sección Descargas o instalarlo a través de la galería NuGet con el siguiente comando:

PM> Install-Package Aspose.Finance

Además, vale la pena mencionar aquí la evolución de OFX. Las versiones 1 a 1.6 de OFX se basan en la sintaxis SGML. Las versiones posteriores se basan en especificaciones XML. Para una mejor comprensión, crearemos archivos de solicitud y respuesta OFX en ambos formatos (1.03 y 2.2).

Crear solicitud OFX programáticamente usando C#

El protocolo OFX es un estándar para un intercambio bidireccional de datos financieros. Puede crear fácilmente una solicitud siguiendo los pasos a continuación:

  1. Inicializar objeto Documento de solicitud de Ofx
  2. Crear instancia de Iniciar sesión en solicitud
  3. Establecer diferentes propiedades
  4. Guardar solicitud OFX en formato 1.03 y 2.2

El fragmento de código a continuación explica cómo crear una solicitud OFX mediante programación utilizando el lenguaje C#:

// Inicializar objeto OfxRequestDocument
OfxRequestDocument document = new OfxRequestDocument();
document.SignonRequestMessageSetV1 = new SignonRequestMessageSetV1();

// Inicialice SignonRequest y establezca diferentes propiedades
SignonRequest signonRequest = new SignonRequest();
document.SignonRequestMessageSetV1.SignonRequest = signonRequest;
signonRequest.ClientDate = "20200611000000";
signonRequest.UserId = "aspose";
signonRequest.UserPassword = "password";
FinancialInstitution fi = new FinancialInstitution();
fi.Organization = "aspose";
fi.FinancialInstitutionId = "1";
signonRequest.FinancialInstitution = fi;
signonRequest.AppVersion = "1.0";
signonRequest.AppId = "Aspose.Finance";
signonRequest.ClientUserId = "aaaaaaa";

document.BankRequestMessageSetV1 = new BankRequestMessageSetV1();
StatementTransactionRequest stmtTransRequest = new StatementTransactionRequest();
document.BankRequestMessageSetV1.StatementTransactionRequests.Add(stmtTransRequest);
stmtTransRequest.TransactionUniqueId = "1111111";
stmtTransRequest.StatementRequest = new StatementRequest();
stmtTransRequest.StatementRequest.BankAccountFrom = new BankAccount();
stmtTransRequest.StatementRequest.BankAccountFrom.BankId = "sssss";
stmtTransRequest.StatementRequest.BankAccountFrom.AccountId = "sfsdfsfsdf";
stmtTransRequest.StatementRequest.BankAccountFrom.AccountType = AccountEnum.CHECKING;
stmtTransRequest.StatementRequest.IncTransaction = new IncTransaction();
stmtTransRequest.StatementRequest.IncTransaction.StartDate = "20200601000000";
stmtTransRequest.StatementRequest.IncTransaction.EndDate = "20200611000000";
stmtTransRequest.StatementRequest.IncTransaction.Include = true;

// Crear solicitud OFX para ambas versiones
document.Save(outputDir + @"newOfxRequestBankStatement.xml", OfxVersionEnum.V2x);
document.Save(outputDir + @"newOfxRequestBankStatement.sgml", OfxVersionEnum.V1x);

Cree una respuesta OFX programáticamente con C#

Puede crear una respuesta OFX en aplicaciones basadas en .NET mediante programación mediante C#. Los siguientes pasos explican el proceso de creación de respuestas OFX:

  1. Inicializar Documento de respuesta Ofx objeto de clase
  2. Declare Respuesta de inicio de sesión y establezca valores
  3. Guarde la respuesta con Ofx Version Enum Enumeración

El siguiente fragmento de código muestra cómo crear una respuesta OFX mediante programación usando C#:

// Inicializar objeto OfxResponseDocument
OfxResponseDocument document = new OfxResponseDocument();
document.SignonResponseMessageSetV1 = new SignonResponseMessageSetV1();

// Inicializar instancia de SignonResponse
SignonResponse signonResponse = new SignonResponse();
document.SignonResponseMessageSetV1.SignonResponse = signonResponse;
signonResponse.Status = new Status();
signonResponse.Status.Code = "0";
signonResponse.Status.Severity = SeverityEnum.INFO;
signonResponse.Status.Message = "SUCCESS";
signonResponse.ServerDate = "20200611";
signonResponse.ProfileUpdateDate = "20200611";
FinancialInstitution fi = new FinancialInstitution();
fi.Organization = "aspose";
fi.FinancialInstitutionId = "1";
signonResponse.FinancialInstitution = fi;
signonResponse.SessionCookie = "11111111111111111";

document.BankResponseMessageSetV1 = new BankResponseMessageSetV1();
StatementTransactionResponse stmtTransResponse = new StatementTransactionResponse();
document.BankResponseMessageSetV1.StatementTransactionResponses.Add(stmtTransResponse);
stmtTransResponse.TransactionUniqueId = "829631324";
stmtTransResponse.Status = new Status();
stmtTransResponse.Status.Code = "0";
stmtTransResponse.Status.Severity = SeverityEnum.INFO;
stmtTransResponse.StatementResponse = new StatementResponse();
stmtTransResponse.StatementResponse.Currency = CurrencyEnum.USD;
stmtTransResponse.StatementResponse.BankAccountFrom = new BankAccount();
stmtTransResponse.StatementResponse.BankAccountFrom.BankId = "1111111";
stmtTransResponse.StatementResponse.BankAccountFrom.AccountId = "1111111111111";
stmtTransResponse.StatementResponse.BankAccountFrom.AccountType = AccountEnum.CHECKING;
stmtTransResponse.StatementResponse.BankTransactionList = new BankTransactionList();
stmtTransResponse.StatementResponse.BankTransactionList.StartDate = "20200601000000";
stmtTransResponse.StatementResponse.BankTransactionList.EndDate = "20200611000000";
StatementTransaction transaction1 = new StatementTransaction();
transaction1.TransactionType = TransactionEnum.DEBIT;
transaction1.PostedDate = "20200611000000";
transaction1.TransactionAmount = "-12";
transaction1.FinancialInstitutionTransactionId = "1111111111111111111111111";
transaction1.Name = "bbbbbbbbbbbbbbbbbbbbbbb";
StatementTransaction transaction2 = new StatementTransaction();
transaction2.TransactionType = TransactionEnum.CREDIT;
transaction2.PostedDate = "20200611000000";
transaction2.TransactionAmount = "22222.11";
transaction2.FinancialInstitutionTransactionId = "2222222222222222222222222222";
transaction2.Name = "wwwwwwwwwwwwwwwwwwwwwwww";
stmtTransResponse.StatementResponse.BankTransactionList.StatementTransactions.Add(transaction1);
stmtTransResponse.StatementResponse.BankTransactionList.StatementTransactions.Add(transaction2);
stmtTransResponse.StatementResponse.LedgerBalance = new LedgerBalance();
stmtTransResponse.StatementResponse.LedgerBalance.BalanceAmount = "+2222.42";
stmtTransResponse.StatementResponse.LedgerBalance.DateAsOf = "20200611000000";
stmtTransResponse.StatementResponse.AvailableBalance = new AvailableBalance();
stmtTransResponse.StatementResponse.AvailableBalance.BalanceAmount = "+222222.42";
stmtTransResponse.StatementResponse.AvailableBalance.DateAsOf = "20200611000000";

// Guarde la respuesta en la especificación de formato OFX 1.03 y 2.2
document.Save(outputDir + @"newOfxResponseBankStatement.xml", OfxVersionEnum.V2x);
document.Save(outputDir + @"newOfxResponseBankStatement.sgml", OfxVersionEnum.V1x);

Conclusión

El estándar OFX es independiente de la plataforma, por lo que los usuarios pueden elegir el entorno del sistema o la plataforma para usar las funciones de procesamiento financiero. Permite a los bancos, casas de bolsa y empresas de procesamiento de nóminas crear soluciones personalizadas. Puede ponerse en contacto a través del Foro de soporte gratuito. ¡Estaremos encantados de ayudarte!

Ver también