Вопрос

Как прочитать .CSV файл с жесткого диска?

Добрый день!

Мне необходимо вызвать веб-сервис и прочитать .csv файл. Версия on-site.

В Исходном коде пишу такой код (код рабочий):

namespace Terrasoft.Configuration
{
	using System.ServiceModel;
	using System.ServiceModel.Web;
	using System.ServiceModel.Activation;
	using Terrasoft.Web.Common;
	using System.Collections.Generic;
 
	[ServiceContract]
	[AspNetCompatibilityRequirements(RequirementsMode = AspNetCompatibilityRequirementsMode.Required)]
	public class ClassService : BaseService
	{
		[OperationContract]
		[WebInvoke(Method = "POST", BodyStyle = WebMessageBodyStyle.Wrapped,
			RequestFormat = WebMessageFormat.Json, ResponseFormat = WebMessageFormat.Json)]
		public void MethodService()
		{
			ReadCSVFile();
		}
		static void ReadCSVFile()
		{
			var lines = System.IO.File.ReadAllLines(@"E:\new1.csv");
			var list = new List<MyContact>();
 
			foreach (var line in lines)
			{
				var values = line.Split(';');
				var myContact = new MyContact() { FirstName = values[0], LastName = values[1], Age = values[2] };
				list.Add(myContact);
			}
		}
	}
 
	public class MyContact
	{
		public string FirstName { get; set; }
		public string LastName { get; set; }
		public string Age { get; set; }
	}
 
}

Проверяю в Postman вызовом веб-сервиса.

Получаю ошибку:

The server encountered an error processing the request. The exception message is 'The device is not ready. '. See server logs for more details. The exception stack trace is:
 
at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath) at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost) at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy, Boolean useLongPath, Boolean checkHost) at System.IO.StreamReader..ctor(String path, Encoding encoding, Boolean detectEncodingFromByteOrderMarks, Int32 bufferSize, Boolean checkHost) at System.IO.StreamReader..ctor(String path, Encoding encoding) at System.IO.File.InternalReadAllLines(String path, Encoding encoding) at Terrasoft.Configuration.QlikClassService.ReadCSVFile() at Terrasoft.Configuration.QlikClassService.QlikMethodService() at SyncInvokeQlikMethodService(Object , Object[] , Object[] ) at System.ServiceModel.Dispatcher.SyncMethodInvoker.Invoke(Object instance, Object[] inputs, Object[]& outputs) at System.ServiceModel.Dispatcher.DispatchOperationRuntime.InvokeBegin(MessageRpc& rpc) at System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage5(MessageRpc& rpc) at System.ServiceModel.Dispatcher.ImmutableDispatchRuntime.ProcessMessage11(MessageRpc& rpc) at System.ServiceModel.Dispatcher.MessageRpc.Process(Boolean isOperationContextSet)

Как я понимаю, надо каким-то образом кроме пути к месту хранения файла, указывать еще что-то? Подскажите что делать.

Нравится

1 комментарий

Проблема решена. Необходимо было в настройках Безопасности конкретного файла добавить IIS_IUSRS и поставить нужные отметки.

Показать все комментарии