当前位置: 首页>>代码示例>>C#>>正文


C# Stream.Read方法代码示例

本文整理汇总了C#中Stream.Read方法的典型用法代码示例。如果您正苦于以下问题:C# Stream.Read方法的具体用法?C# Stream.Read怎么用?C# Stream.Read使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Stream的用法示例。


在下文中一共展示了Stream.Read方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: ReadMetaData

 public ImageMetaData ReadMetaData(Stream stream)
 {
     var header = new byte[0x20];
     if (0x20 != stream.Read(header, 0, 0x20))
         return null;
     if (!Binary.AsciiEqual(header, 0, "xtx\0"))
     {
         var header_size = LittleEndian.ToUInt32(header, 0);
         if (header_size >= 0x1000) // XXX use some arbitrary "large" value to avoid call to Stream.Length
             return null;
         stream.Position = header_size;
         if (0x20 != stream.Read(header, 0, 0x20))
             return null;
         if (!Binary.AsciiEqual(header, 0, "xtx\0"))
             return null;
     }
     if (header[4] > 2)
         return null;
     int aligned_width = BigEndian.ToInt32(header, 8);
     int aligned_height = BigEndian.ToInt32(header, 0xC);
     if (aligned_width <= 0 || aligned_height <= 0)
         return null;
     return new XtxMetaData
     {
         Width = BigEndian.ToUInt32(header, 0x10),
         Height = BigEndian.ToUInt32(header, 0x14),
         OffsetX = BigEndian.ToInt32(header, 0x18),
         OffsetY = BigEndian.ToInt32(header, 0x1C),
         BPP = 32,
         Format = header[4],
         AlignedWidth = aligned_width,
         AlignedHeight = aligned_height,
         DataOffset = (uint)stream.Position,
     };
 }
开发者ID:xmoeproject,项目名称:X-moe,代码行数:35,代码来源:ImageTXT.cs

示例2: CheckKeyForMessage

        public static long CheckKeyForMessage(Stream keyStream, long messageLength)
        {
            long messageLengthBits = messageLength * 8;
            long countRequiredSamples = 0;

            if (messageLengthBits > keyStream.Length)
            {
                long keyLength = keyStream.Length;

                byte[] keyBytes = new byte[keyLength];
                keyStream.Read(keyBytes, 0, keyBytes.Length);

                countRequiredSamples = SumKeyArray(keyBytes);

                double countKeyCopies = messageLengthBits / keyLength;

                countRequiredSamples = (long)(countRequiredSamples * countKeyCopies);

            }
            else
            {
                byte[] keyBytes = new byte[messageLengthBits];
                keyStream.Read(keyBytes, 0, keyBytes.Length);
                countRequiredSamples = SumKeyArray(keyBytes);
            }

            keyStream.Seek(0, SeekOrigin.Begin);
            return countRequiredSamples;
        }
开发者ID:prannoytank,项目名称:WavSteganography,代码行数:29,代码来源:WaveUtility.cs

示例3: ModsDemuxer

 public ModsDemuxer(Stream Stream)
 {
     this.Stream = Stream;
     Header = new ModsHeader(Stream);
     if (Header.AudioOffset != 0)
     {
         AudioCodebooks = new byte[Header.NbChannel][];
         Stream.Position = Header.AudioOffset;
         for (int i = 0; i < Header.NbChannel; i++)
         {
             AudioCodebooks[i] = new byte[0xC34];
             Stream.Read(AudioCodebooks[i], 0, 0xC34);
         }
     }
     KeyFrames = new KeyFrameInfo[Header.KeyframeCount];
     Stream.Position = Header.KeyframeIndexOffset;
     byte[] tmp = new byte[8];
     for (int i = 0; i < Header.KeyframeCount; i++)
     {
         KeyFrames[i] = new KeyFrameInfo();
         Stream.Read(tmp, 0, 8);
         KeyFrames[i].FrameNumber = IOUtil.ReadU32LE(tmp, 0);
         KeyFrames[i].DataOffset = IOUtil.ReadU32LE(tmp, 4);
     }
     JumpToKeyFrame(0);
 }
开发者ID:elfinlazz,项目名称:MobiclipDecoder,代码行数:26,代码来源:ModsDemuxer.cs

示例4: Copy

        public static int Copy(Stream source, Stream destination, byte[] buffer, int? mask, int count)
        {
            int totalRead = 0, read;
            if(mask == null)
            {
                while (count > 0 && (read = source.Read(buffer, 0, Math.Min(count, buffer.Length))) > 0)
                {
                    destination.Write(buffer, 0, read);
                    totalRead += read;
                    count -= read;
                }
            } else
            {
                int effectiveLength = (buffer.Length/8)*8; // need nice sized! e.g. 100-byte array, can only use 96 bytes
                if(effectiveLength == 0) throw new ArgumentException("buffer is too small to be useful", "buffer");

                // we read it big-endian, so we need to *write* it big-endian, and then we'll use unsafe code to read the value,
                // so that the endian-ness we use is CPU-endian, and so it matches whatever we do below
                int maskValue = mask.Value;
                buffer[0] = buffer[4] = (byte) (maskValue >> 24);
                buffer[1] = buffer[5] = (byte) (maskValue >> 16);
                buffer[2] = buffer[6] = (byte) (maskValue >> 8);
                buffer[3] = buffer[7] = (byte) maskValue;
                unsafe
                {
                    
                    fixed (byte* bufferPtr = buffer) // treat the byte-array as a pile-of-ulongs
                    {
                        var longPtr = (ulong*)bufferPtr;
                        ulong xorMask = *longPtr;
                        int bytesThisIteration;
                        do
                        {
                            // now, need to fill buffer as much as possible each time, as we want to work in exact
                            // units of 8 bytes; we don't need to worry about applying the mask to any garbage at the
                            // end of the buffer, as we simply won't copy that out
                            int offset = 0, available = effectiveLength;
                            while (available > 0 && (read = source.Read(buffer, offset, Math.Min(count, available))) > 0)
                            {
                                available -= read;
                                totalRead += read;
                                count -= read;
                                offset += read;
                            }
                            bytesThisIteration = effectiveLength - available;
                            int chunks = bytesThisIteration/8;
                            if ((available%8) != 0) chunks++;

                            // apply xor 8-bytes at a time, coz we haz 64-bit CPU, baby!
                            for (int i = 0; i < chunks; i++)
                                longPtr[i] ^= xorMask;

                            destination.Write(buffer, 0, bytesThisIteration);
                        } while (bytesThisIteration != 0);
                    }
                }
            }
            if(count != 0) throw new EndOfStreamException();
            return totalRead;
        }
开发者ID:mpotra,项目名称:NetGain,代码行数:60,代码来源:WebSocketsProcessor_RFC6455_13.cs

示例5: CreateV1Frames

        private void CreateV1Frames(Stream stream)
        {
            // ID1 header am ende ...
            stream.Seek(-125, SeekOrigin.End);
            // 30 zeichen title     => TIT2
            // 30 zeichen artist    => TCOM
            // 30 zeichen album     => TALB
            // 4 zeichen jahr       => TYER
            // 30 zeichen commentar - kann auch den track enthalten (TRCK) - der letzte byte
            // 1 byte Genre
            // == 125

            foreach (var item in new[] { "TIT2", "TCOM", "TALB" })
            {
                AddFrame(item, ByteHelper.BytesToString(stream.Read(30)));
            }
            AddFrame("TYER", ByteHelper.BytesToString(stream.Read(4)));

            // comment - egal
            stream.Seek(28, SeekOrigin.Current);
            var track = stream.Read(2);
            if (track[0] == 0 && track[1] != 0)
            {
                // dann ist track[1] eine zahl;
                if (track[1] < 48)
                {
                    AddFrame("TRCK",((int)track[1]).ToString());
                }
            }
        }
开发者ID:Epibatidin,项目名称:FLUX,代码行数:30,代码来源:ID3V23TagReader.cs

示例6: Upload

        public void Upload(TransferInfo transferInfo, Stream data)
        {
            // Compute how much will be left over for the last chunk
            long dataLength = data.Length;
            long chunkSize = SendChunkSize == 0 ? 256000 : SendChunkSize;
            long remainder = dataLength % chunkSize;
            long chunkCount = dataLength / chunkSize;

            // Handle the case of small files
            if (chunkSize >= dataLength)
            {
                chunkSize = dataLength;
                remainder = 0;
                chunkCount = 1;
            }

            string sessionId = m_Proxy.BeginUploadSession(transferInfo);
            for (long index = 0; index < chunkCount; index++)
            {
                byte[] chunk = new byte[chunkSize];
                data.Read(chunk, (int)(index * chunkSize), (int)chunkSize);
                m_Proxy.UploadChunk(sessionId, chunk);
            }
            if (remainder > 0)
            {
                byte[] chunk = new byte[remainder];
                data.Read(chunk, (int)(chunkCount * chunkSize), (int)remainder);
                m_Proxy.UploadChunk(sessionId, chunk);
            }
            m_Proxy.CompleteUpload(sessionId);

        }
开发者ID:zjlgdx,项目名称:cats,代码行数:32,代码来源:ChunkingTransferServiceWrapper.cs

示例7: UploadFile

        public string UploadFile(string fileName, Stream content)
        {
            // 我们不知道HTTP请求流的长度,所以我们必须使用以下代码读出流的长度:
            int bufferSize = 4096;
            int bytesRead = 1;
            int totalBytesRead = 0;
            try
            {
                using (FileStream fileStream = File.Create(fileName))
                {
                    byte[] buffer = new byte[bufferSize];
                    bytesRead = content.Read(buffer, 0, bufferSize);
                    while (bytesRead > 0)
                    {
                        fileStream.Write(buffer, 0, bytesRead);
                        bytesRead = content.Read(buffer, 0, bufferSize);
                        totalBytesRead += bytesRead;
                    }
                }

                // 按照REST服务的最近实践,当资源被创建时,返回一个201 Created状态代码代理默认的200.
                // 这意味着Silverlight客户端必须使用HTTP栈,替代默认的浏览器HTTP栈使用服务来工作.
                return WriteResponse(HttpStatusCode.Created, "Created.");
            }
            catch (Exception ex)
            {
                return WriteResponse(HttpStatusCode.InternalServerError, ex.Message);
            }
        }
开发者ID:zealoussnow,项目名称:OneCode,代码行数:29,代码来源:RestService.cs

示例8: GetCrc32AndCopy

		/// <summary>
		/// Returns the CRC32 for the specified stream, and writes the input into the output stream.
		/// </summary>
		/// <param name="input">The stream over which to calculate the CRC32</param>
		/// <param name="output">The stream into which to deflate the input</param>
		/// <returns>the CRC32 calculation</returns>
		public UInt32 GetCrc32AndCopy(Stream input, Stream output)
		{
			unchecked
			{
				UInt32 crc32Result;
				crc32Result = 0xFFFFFFFF;
				byte[] buffer = new byte[BufferSize];
				int readSize = BufferSize;

				m_TotalBytesRead = 0;
				int count = input.Read(buffer, 0, readSize);
				if (output != null) output.Write(buffer, 0, count);
				m_TotalBytesRead += count;
				while (count > 0)
				{
					for (int i = 0; i < count; i++)
					{
						crc32Result = ((crc32Result) >> 8) ^ m_crc32Table[(buffer[i]) ^ ((crc32Result) & 0x000000FF)];
					}
					count = input.Read(buffer, 0, readSize);
					if (output != null) output.Write(buffer, 0, count);
					m_TotalBytesRead += count;

				}

				return ~crc32Result;
			}
		}
开发者ID:koder05,项目名称:fogel-ba,代码行数:34,代码来源:Crc32.cs

示例9: Decode

        // Source: http://blogs.msdn.com/b/feroze_daud/archive/2004/03/30/104440.aspx
        public static String Decode(WebResponse response, Stream stream)
        {
            String charset = null;
            String contentType = response.Headers["content-type"];
            if(contentType != null)
            {
                int index = contentType.IndexOf("charset=");
                if(index != -1)
                {
                    charset = contentType.Substring(index + 8);
                }
            }

            MemoryStream data = new MemoryStream();
            byte[] buffer = new byte[1024];
            int read = stream.Read(buffer, 0, buffer.Length);
            while(read > 0)
            {
                data.Write(buffer, 0, read);
                read = stream.Read(buffer, 0, buffer.Length);
            }
            stream.Close();

            Encoding encoding = Encoding.UTF8;
            try
            {
                if(charset != null)
                    encoding = Encoding.GetEncoding(charset);
            }
            catch { }

            data.Seek(0, SeekOrigin.Begin);
            StreamReader streamReader = new StreamReader(data, encoding);
            return streamReader.ReadToEnd();
        }
开发者ID:Gohla,项目名称:Gohla.Shared,代码行数:36,代码来源:HTTPUtility.cs

示例10: Get

		public static FileSystemRecord Get(Stream volume, byte[] buffer1, byte[] buffer2, int sector)
		{
			DirectoryRecord directory;
			FileRecord file;

			long pos = (long)sector * 512L;
			volume.Position = pos;
			volume.Read(buffer1, 0, 512);
			if (BitConverter.ToUInt32(buffer1, 4) != 1179208773)
			{ 
				directory = new DirectoryRecord();
				directory.Name = sector.ToString();
				Console.WriteLine("Not a FILE record, " + sector + "!"); 
				return directory;
			}

			pos = (long)BitConverter.ToInt32(buffer1, 8) * 512L;
			volume.Position = pos;
			volume.Read(buffer2, 0, 512);

			switch (BitConverter.ToUInt32(buffer2, 4))
			{
				case 1179208773: // child is a FILE, it's a dir!
					directory = new DirectoryRecord();
					FillFileSystemRecord(volume, buffer1, directory);
					int next = directory.Child;
					while (next != 0)
					{
						directory.Children.Add(next);
						volume.Position = (long)next * 512L;
						volume.Read(buffer1, 0, 512);
						next = BitConverter.ToInt32(buffer1, 60);
					}
					return directory;
				case 1414677829: // child is a TREE, it's a dir again!
					directory = new DirectoryRecord();
					FillFileSystemRecord(volume, buffer1, directory);
					FillTree(volume, buffer2, directory.Child, sector, directory.Children);
					return directory;
				case 1095520067: // child is an ALOC, it's a file!
					file = new FileRecord();
					FillFileSystemRecord(volume, buffer1, file);
					file.Allocation = ByteKiller(buffer2, 8, 496);
					file.AllocationStart = file.Child + file.Allocation[1];
					file.Allocation[1] = 0;
					file.UnusedBytes = BitConverter.ToInt32(buffer2, 504);
					file.SectorCount = BitConverter.ToInt32(buffer2, 508);
					if (file.SectorCount * 512 - file.UnusedBytes != file.Size) Console.WriteLine("File " + sector + " isn't correct size!");
					return file;
				default: // usually empty file
					file = new FileRecord();
					FillFileSystemRecord(volume, buffer1, file);
					file.Allocation = new int[0];
					file.AllocationStart = 0;
					file.UnusedBytes = 0;
					file.SectorCount = 0;
					if (file.Child != 0) Console.WriteLine("Uh, I dunno what's the problem, " + sector + ".");
					return file;
			}
		}
开发者ID:Renzovasc,项目名称:decorder,代码行数:60,代码来源:FileSystemRecord.cs

示例11: DecryptStream

        /// <summary>
        /// Производит дешифрование потока.
        /// </summary>
        /// <param name="inputStream">Поток, который будет дешифрован.</param>
        /// <param name="outputStream">Поток, в который будет записан результат дешифрования.</param>
        /// <param name="Key">Ключ для дешифрования.</param>
        public void DecryptStream(Stream inputStream, Stream outputStream, byte[] Key)
        {
            ThrowIfDisposed();

              if (inputStream == null || outputStream == null || Key == null)
            throw new ArgumentNullException("One of the arguments (or all) equals null");

              int maxBufferSizeValue = bufferCoefficient * ConstBufferCoefficient;

              byte[] originFileLengthArray = new byte[sizeof(long)];
              byte[] iv = new byte[cryptAlgorithm.BlockSize / 8];

              inputStream.Read(originFileLengthArray, 0, sizeof(long));
              inputStream.Read(iv, 0, cryptAlgorithm.BlockSize / 8);

              long deltaLength = inputStream.Length - HeadSize - cryptAlgorithm.BlockSize / 8 - BitConverter.ToInt64(originFileLengthArray, 0);

              using (var transform = cryptAlgorithm.CreateDecryptor(Key, iv))
              {
            using (var csEncrypt = new CryptoStream(inputStream, transform, CryptoStreamMode.Read))
            {
              var dataBuffer = new byte[maxBufferSizeValue];

              while (inputStream.Position < inputStream.Length)
              {
            int dataSize = (inputStream.Length - inputStream.Position > maxBufferSizeValue) ? maxBufferSizeValue : (int)(inputStream.Length - inputStream.Position - deltaLength);

            csEncrypt.Read(dataBuffer, 0, dataSize);
            outputStream.Write(dataBuffer, 0, dataSize);
              }
            }
              }
        }
开发者ID:Nowsoud,项目名称:TCPChat,代码行数:39,代码来源:Crypter.cs

示例12: while

      Stream lStream = fStorage.GetFile(SecureFileName, 0); 
      try
      {

        byte[] lBuffer = new byte[BUFFER_SIZE];
        
        int lBytesRead = lStream.Read(lBuffer, 0, BUFFER_SIZE);
        while (lBytesRead > 0)
        {
          aToStream.Write(lBuffer,0,lBytesRead);
          lBytesRead = lStream.Read(lBuffer, 0, BUFFER_SIZE);
        }
      }
      finally
      {
        lStream.Close();
      }

      //return new FileStream(SecureFileName,FileMode.Open, FileAccess.Read, FileShare.Read);
    }
    const int BUFFER_SIZE = 64*1024;

    public override void CreateFile(Stream aStream)
    {
      if (File.Exists(SecureFileName))
        throw new Exception("Error adding file to secure storage: file already exist.");
      
      //Stream lStream = new FileStream(SecureFileName,FileMode.CreateNew, FileAccess.Write, FileShare.None);
      Stream lStream = fStorage.CreateFile(SecureFileName); 
      try
      {
开发者ID:nolith,项目名称:internetpack,代码行数:31,代码来源:SecureFile.cs

示例13: Read

        public Texture2D Read(Stream inputStream, GraphicsDevice graphicsDevice)
        {
            if (IsPngImage(inputStream) == false)
            {
                throw new Exception("File does not have PNG signature.");
            }

            inputStream.Position = 8;

            while (inputStream.Position != inputStream.Length)
            {
                byte[] chunkDataLengthBytes = new byte[4];
                inputStream.Read(chunkDataLengthBytes, 0, 4);
                uint chunkDataLength = chunkDataLengthBytes.ToUInt();

                inputStream.Position -= 4;

                byte[] chunkBytes = new byte[12 + chunkDataLength];
                inputStream.Read(chunkBytes, 0, (int)(12 + chunkDataLength));

                ProcessChunk(chunkBytes);
            }

            UnpackDataChunks();

            texture = new Texture2D(graphicsDevice, width, height, false, SurfaceFormat.Color);
            texture.SetData<Color>(data);

            return texture;
        }
开发者ID:KennethYap,项目名称:MonoGame,代码行数:30,代码来源:PngReader.cs

示例14: FrameScanner

        public FrameScanner(Stream input)
        {
            input.Seek(0, SeekOrigin.Begin);
            byte[] frameheadbuffer = new byte[byte.MaxValue + 4];
            byte[] buffer = new byte[6];
            input.Read(buffer, 0, 6);
            headerOkay = Encoding.ASCII.GetString(buffer, 0, 4) == "MMDb";
            if (!headerOkay)
                return;
            version = new Version(buffer[4], buffer[5]);

            if (version == FileVersions.First)
            {
                input.Read(buffer, 0, 4);
                id = BitConverter.ToInt32(buffer, 0);

                while (input.Position < input.Length)
                {
                    byte b = (byte)input.ReadByte();
                    input.Read(frameheadbuffer, 0, 4 + b);
                    FrameIdentifier identifier = new FrameIdentifier(frameheadbuffer, 0, b);
                    int length = BitConverter.ToInt32(frameheadbuffer, b);
                    int position = (int)input.Position;
                    Frame frame = new Frame(position, length, 5 + b);
                    frames.Add(identifier, frame);
                    input.Seek(length, SeekOrigin.Current);
                }
            }
            else
            {
                headerOkay = false;
                return;
            }
        }
开发者ID:Tonaplo,项目名称:DeadDog.Movies,代码行数:34,代码来源:FrameScanner.cs

示例15: TryRead

        public static bool TryRead(Stream stream, out LengthedPrefixedString s)
        {
            s = null;
            if (!MatchHeader(stream))
                return false;

            var lengthBytes = new byte[4];
            if (stream.Read(lengthBytes, 0, 4) < 4)
                return false;

            int length = BitConverter.ToInt32(lengthBytes, 0);
            var stringBytes = new byte[length];

            if (stream.Read(stringBytes, 0, length) < length)
                return false;
            try
            {
                string data = Encoding.UTF8.GetString(stringBytes);
                s = new LengthedPrefixedString(data);
            }
            catch
            {
                return false;
            }

            if (!HasTerminator(stream))
                return false;

            return true;
        }
开发者ID:beyond-code-github,项目名称:CacheCow,代码行数:30,代码来源:LengthedPrefixedString.cs


注:本文中的Stream.Read方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。